码迷,mamicode.com
首页 > 其他好文 > 详细

暴雪战网安全令的原理

时间:2014-07-22 22:36:12      阅读:194      评论:0      收藏:0      [点我收藏+]

标签:java   使用   数据   c   算法   时间   

1、首先创建一个56位的byte数组,结构如下:
00 byte[1] 固定为1;
01 byte[37] 37位的随机数据,只使用一次,用来解密服务器返回数据;
38 byte[2] 区域码: US or EU;or CN
40 byte[16] 设备模型数据(手机型号,或者任意数据)

2、向服务器请求创建数据发送请求
获取服务器返回数据,长度应该为45位,结构如下:
00 - 07 服务器时间(网络字节序,计算本地时间与服务器时间的差值);
08 - 45 通过步骤1中37位随机数据加密过的数据(包括序列号和私钥)

3、将步骤2中08 - 45这37位数据进行解密
操作方法为与步骤1中的37位随机数据按位进行 “与或”操作
解密后的37位数据结构如下:
00 - 19 私钥(私钥就是计算验证码所用的钥匙)
20 - 37 序列号(格式为US-xxxx-xxxx-xxxx,就是在战网上绑定到账户所需要的14位数字序号,输入的时候,不需要中间的连字符)

这也就是为什么所有版本的手机验证器(包括java,安卓等)第一次启动需要联网的原因,以后启动则无需联网,只需要通过私钥将当前时间加密即可,除非本地时间更改,与服务器不同步

4、获取验证码
将当前时间,通过时间差值计算出服务器时间
然后服务器时间除以30000(毫秒,即30秒,也就是每半分钟更换一次验证码)
将该值通过步骤3中的私钥,经过SHA1算法计算出结果(SHA1算法很常见,这里不赘述),这个结果就是验证码 .

暴雪战网安全令的原理,布布扣,bubuko.com

暴雪战网安全令的原理

标签:java   使用   数据   c   算法   时间   

原文地址:http://www.cnblogs.com/flyFreeZn/p/3860795.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!