Solved

Trial system

Posted on 1998-07-24
9
250 Views
Last Modified: 2010-05-03
Anybody got some sample code for a twenty day trial system?

Rob.
0
Comment
Question by:robjgreen
  • 5
  • 4
9 Comments
 
LVL 8

Expert Comment

by:MikeP090797
ID: 1466614
What do you mean? A program that will run for only 20 days since it's installation? How well protected should it be?
0
 

Author Comment

by:robjgreen
ID: 1466615
The user should not be able to stop it from expiring...
0
 
LVL 8

Accepted Solution

by:
MikeP090797 earned 100 total points
ID: 1466616
The general approach would be to store the installation in the registry, using DateValue so it will be stored as a long number and not as a readable date, and compare it to today's date. If the difference is more then 20 days, exit. If the date in the registry isn't found, exit. If you are planning it for the average user, using SaveSetting will be enough, he won't be able to modify the date. If you are planning it for high level experts, you should use Reg* APIs to store it elsewhere so noone will figure out it's your program, or store it in a file like prog10xs.dll in \windows\system directory, so the user won't figure it out either. Make the file 20KB long, so it won't look suspicious
0
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 

Author Comment

by:robjgreen
ID: 1466617
Hi Mike,
   Well, that is actually what I had done already, simply stored it in the registry... but I'm going to test your DateValue idea before I accept the answer (low on points!)

Kind Regs,
Rob Green.
0
 
LVL 8

Expert Comment

by:MikeP090797
ID: 1466618
Sorry, I posted it to early. DateValue won't do it, but you can store it like Day*10+Month*500+Year*7000
0
 

Author Comment

by:robjgreen
ID: 1466619
Hi Mike,
   it seems to be working okay... I'll have to get a decent install program that can set these things up though.

Kind Regards,
Rob Green.
0
 

Author Comment

by:robjgreen
ID: 1466620
Mike, erm... well I used this code:

Private Sub Form_Load()
    Dim installdat, currentdate As Long
    frmUnReg.Picture = frmSplash.Picture
    installdate = GetSetting("Heatwave Creations", "PasswordSafe", "gg1", "")
    currentdate = DateValue(Date)
    difference = currentdate - installdate
End Sub

Private Sub Timer1_Timer()
    If (20 - difference) > 0 Then
        frmPasswordSafe.Visible = True
        frmPasswordSafe.Enabled = False
        frmLogin.Visible = True
        Unload Me
    ElseIf (20 - difference) <= 0 Then
        MsgBox "Your Trial Has Expired"
        frmPreferences.Visible = True
        Unload Me
    End If
End Sub

But it doesnt work, it claims I have 40 days remaining!

Can you write me a code example please?

Kind Regards,
Rob Green.
0
 
LVL 8

Expert Comment

by:MikeP090797
ID: 1466621
Try something like:
Dim InstallDate as date
installdate = GetSetting("Heatwave Creations", "PasswordSafe", "gg1", "")

If DateDiff("m", Now, InstallDate)>20 then
'Exit
else
'Continue
End if
0
 

Author Comment

by:robjgreen
ID: 1466622
Its okay, I rewrote all the code and it works okay now...
Cant remember what was wrong... too noisy here to think.
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Link a textbox in excel to a cell with more than 255 characters. 5 83
Vb.net 2008 2 58
VBA saving file message display 5 63
Spell Check in VB6 13 112
There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

813 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now