Solved

Password protecting against date changes

Posted on 2006-11-27
4
138 Views
Last Modified: 2010-04-30
I have password protected my software by generating a password that relates to hard disc ID, computer name, email, date of installation etc. Is there an easy way to prevent users changing the system date to reactivate the software after a license period expires?
0
Comment
Question by:pgalloway
  • 2
4 Comments
 
LVL 10

Expert Comment

by:Clif
Comment Utility
I presume you store the info in a hidden file (or in the registry)

What you can do is also store that last date the info was requested that was on or after the currently stored date.  If the system date ends up being before the stored date, you know the user changed the system date and you can deactivate your app.

I don't know how you're storing your password, so I can't give you code.  But, hopefully, you understand what I'm saying and can implement it.
0
 

Author Comment

by:pgalloway
Comment Utility
OK this is very obvious really, when you know how. Thanks very much Clif.
0
 
LVL 10

Accepted Solution

by:
Clif earned 125 total points
Comment Utility
I'm thinking something like this:

    Dim dtNow As Date
    dtNow = Now
    Dim dtStoredDate As Date
    dtStoredDate = GetSetting(App.EXEName, "Security", "Date", dtNow)
    If dtStoredDate > dtNow Then
        'The system click has been altered in an attempt
        'to override licensing
    Else
        SaveSetting App.EXEName, "Security", "Date", dtNow
    End If
0
 
LVL 29

Expert Comment

by:nffvrxqgrcfqvvc
Comment Utility
If the users date is pulled back to an earlier date than you should disable using the program all together and end the trial period regardless of how many days would be remaining. In reality the indivudual who sets the clock back to try and bypass the trial for more days isn't really interested in purchasing your software. Now you may say what about the other reasons that might occur, pherhaps the date changing because of a bad bios or by other means. Don't worry about those situations they won't blame your trial method but the computer itself.

The idea is to subclass for a WM_TIMECHANGE ( http://vbnet.mvps.org/index.html?code/subclass/datetime.htm )
You should also check if the computer is connected to the internet and query a time server, this can't be changed by the user so it will always work behind the scenes. Also make sure if the user doesn't have a connection to have a backup method, I wouldn't recommend using a file to store the date and time settings. I would use the registry and set a dacl on the hkey so the user can't open the key to edit the values.
0

Featured Post

Top 6 Sources for Identifying Threat Actor TTPs

Understanding your enemy is essential. These six sources will help you identify the most popular threat actor tactics, techniques, and procedures (TTPs).

Join & Write a Comment

Suggested Solutions

Title # Comments Views Activity
Share codes 68 114
Public Sub, Empty Cell 7 56
VB error "Type mismatch" 2 42
Protecting vb6 & .Net code Obfuscation 18 43
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
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…

763 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

6 Experts available now in Live!

Get 1:1 Help Now