先交代一下应用场景:我们的软件需要做一个简单的有效期验证保护。初始的想法是
在本地将安装时间、启动时间、当前时间做比较,为了防止记录被修改,记录在注册表的特殊的地方并加密。
我使用了.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;