zoukankan      html  css  js  c++  java
  • 暴雪战网安全令的原理

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

  • 相关阅读:
    前端开发--vue开发部分报错指南
    前端开发--Mongodb篇
    前端开发--nginx番外篇
    前端开发--nginx篇
    Mac笔记本使用小道解答集
    vue开发路由相关基础知识和笔记
    PostCSS的插件 -- 关于vue rem适配布局方案
    Nodejs -- 使用koa2搭建数据爬虫
    mac OSX 实用快捷键
    如何将自己的vue组件发布为npm包
  • 原文地址:https://www.cnblogs.com/flyFreeZn/p/3860795.html
Copyright © 2011-2022 走看看