37玩登录js逆向分析(简单)

文章目录

          • 1. 网址
          • 2. 模拟登录
          • 3. 全局搜索`password=`
          • 4. 在可疑处打断点
          • 5. js源码

1. 网址

https://www.37.com/?refer=baidu_pptg

2. 模拟登录

37玩登录js逆向分析(简单)_第1张图片

3. 全局搜索password=

找到两个js文件,依次点进去查看
37玩登录js逆向分析(简单)_第2张图片

4. 在可疑处打断点

测试密码:123456;
位置正确,通过td加密
37玩登录js逆向分析(简单)_第3张图片
进入td 方法里面;
整个文件就45行代码,都是加密相关的逻辑,全部复制下来即可

37玩登录js逆向分析(简单)_第4张图片

5. js源码
var ch = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
function __rsa(str) {
    var out, i, len;
    var c1, c2, c3;
    len = str.length;
    i = 0;
    out = "";
    while (i < len) {
        c1 = str.charCodeAt(i++) & 0xff;
        if (i == len) {
            out += ch.charAt(c1 >> 2);
            out += ch.charAt((c1 & 0x3) << 4);
            out += "==";
            break
        }
        c2 = str.charCodeAt(i++);
        if (i == len) {
            out += ch.charAt(c1 >> 2);
            out += ch.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
            out += ch.charAt((c2 & 0xF) << 2);
            out += "=";
            break
        }
        c3 = str.charCodeAt(i++);
        out += ch.charAt(c1 >> 2);
        out += ch.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
        out += ch.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >> 6));
        out += ch.charAt(c3 & 0x3F)
    }
    return out
}
function td(a) {
    var maxPos = ch.length - 2
      , w = [];
    for (i = 0; i < 15; i++) {
        w.push(ch.charAt(Math.floor(Math.random() * maxPos)));
        if (i === 7) {
            w.push(a.substr(0, 3))
        }
        if (i === 12) {
            w.push(a.substr(3))
        }
    }
    return __rsa(w.join(""))
}

你可能感兴趣的:(Encryption,and,decryption)