• 暴雪战网安全令的原理


    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算法很常见,这里不赘述),这个结果就是验证码 .

  • 相关阅读:
    CSS3(4)---动画(animation)
    MDT 2010驱动管理新方法。
    windows 2012 试用180天
    Mac地址绑定的wifi
    用于主题检测的临时日志(b2d5c7b3-e3f6-4b0f-bfa4-a08e923eda9b
    samba4.1.9安装
    samba权限之easy举例说明--原创
    NFS性能优化
    工作组环境下管理windows.
    管理windows防火墙
  • 原文地址:https://www.cnblogs.com/flyFreeZn/p/3860795.html
Copyright © 2020-2023  润新知