Password protecting against date changes

Posted on 2006-11-27
Medium Priority
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?
Question by:pgalloway
  • 2
LVL 10

Expert Comment

ID: 18022406
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.

Author Comment

ID: 18022448
OK this is very obvious really, when you know how. Thanks very much Clif.
LVL 10

Accepted Solution

Clif earned 500 total points
ID: 18022800
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
        SaveSetting App.EXEName, "Security", "Date", dtNow
    End If
LVL 29

Expert Comment

ID: 18024146
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.

Featured Post

Upgrade your Question Security!

Your question, your audience. Choose who sees your identity—and your question—with question security.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Introduction In a recent article (http://www.experts-exchange.com/A_7811-A-Better-Concatenate-Function.html) for the Excel community, I showed an improved version of the Excel Concatenate() function.  While writing that article I realized that no o…
Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
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…

624 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