先交代一下应用场景:我们的软件需要做一个简单的有效期验证保护。初始的想法是
在本地将安装时间、启动时间、当前时间做比较,为了防止记录被修改,记录在注册表的特殊的地方并加密。
我使用了.net自带的rsa加密方法;这样一来,带来了一些麻烦,首先我必须存储公钥,私钥用来加密和解密(解决这个问题时,我采用了相当蠢的办法,我把他们跟时间记录在一起);第二我还得处理因为公私钥可能被改变而引起的异常;当然还有360拦截写入注册表的异常。总之,麻烦一堆。
所幸,后端的同学提供了一个服务,查询当前的Unix时间戳。于是有了这个问题。
1 //
2 // Unix时间戳(timestamp)转换成当地时间的方法
3 // timestamp转成double后,扩大10000000倍,转成long,得到ltime
4 // ltime是从格林威治时间的计时起点(1970-01-01 00:00:00)到现在的时间间隔,转成TimeSpan,得到ts
5 // 计算格林威治的计时起点转成当地时间的DateTime,得到glwzStart
6 // 用glwzStart加上时间间隔ts,得到当前的当地时间
7 //
8 double dtime = double.TryParse(time, out dtime) ? dtime : 0;
9 long ltime = (long)(dtime * 10000000);
10 TimeSpan ts = new TimeSpan(ltime);
11 DateTime glwzStart = TimeZone.CurrentTimeZone.ToLocalTime(DateTime.Parse("1970-1-1 00:00:00"));
12 DateTime cur = glwzStart.Add(ts);
13 if (cur >= DateTime.Parse(ExpirationDate))
14 return 1;
15 else
16 return 0;