Solved

Password protecting against date changes

Posted on 2006-11-27
4
141 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
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.
0
 

Author Comment

by:pgalloway
ID: 18022448
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
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
    Else
        SaveSetting App.EXEName, "Security", "Date", dtNow
    End If
0
 
LVL 29

Expert Comment

by:nffvrxqgrcfqvvc
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.
0

Featured Post

Active Directory Webinar

We all know we need to protect and secure our privileges, but where to start? Join Experts Exchange and ManageEngine on Tuesday, April 11, 2017 10:00 AM PDT to learn how to track and secure privileged users in Active Directory.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
using web browser with BING 40 132
How to make an ADE file by code? 11 94
Dinamic report to Crosstab query 9 35
checkbox to hide entire section 10 43
Introduction While answering a recent question about filtering a custom class collection, I realized that this could be accomplished with very little code by using the ScriptControl (SC) library.  This article will introduce you to the SC library a…
You can of course define an array to hold data that is of a particular type like an array of Strings to hold customer names or an array of Doubles to hold customer sales, but what do you do if you want to coordinate that data? This article describes…
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…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…

820 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