某志愿网js逆向

逆向过程分析与js代码扣取

请求头U-Sign数据

image.png

通过浏览器开发者工具可以看到返回数据的接口/youzy.dms.basiclib.api.college.query

image.png

添加XHR断点刷新浏览器会自动进入断点

image.png

查看具体请求数据,将断点定位到r = r.then(t.shift(), t.shift());

image.png

F8跳转到改断点位置,可以看到有5个方法

image.png

点击[[FunctionLocation]]:后的js查看方法,发现第一个方法里面有u-sign

image.png

将断点定位到u-sign,并将上一步的断点放开,F8定位到u-sign

image.png

  • 发现u-sign由o方法生成

image.png

  • 复制出url和data的值,data可以直接右键复制对象

image.png

data = {
    "keyword": "",
    "provinceNames": [],
    "natureTypes": [],
    "eduLevel": "",
    "categories": [],
    "features": [],
    "pageIndex": 1,
    "pageSize": 20,
    "sort": 11
}

进入o方法,断点并执行

image.png
观察发现该方法,发现参数o只是做了一个拼接,数据加密由n(o)完成,i值为固定值,a值为请求参数

var i = "9SASji5OWnG41iRKiSvTJHlXHmRySRp1"
o = Object.keys(a).length > 0 ? "".concat(JSON.stringify(a), "&").concat(i) : "&".concat(i);
o = o.toLowerCase()
n(o)

image.png

进入n方法并断点

image.png
复制出方法并改成正常方法

// 防止重名改为exports123
exports123 = function(e, r) {
  if (null == e)
    throw new Error("Illegal argument " + e);
  var n = t.wordsToBytes(a(e, r));
  return r && r.asBytes ? n : r && r.asString ? o.bytesToString(n) : t.bytesToHex(n)
}

我们现在可以得到js

var i = "9SASji5OWnG41iRKiSvTJHlXHmRySRp1",
		data = {
        "keyword": "",
        "provinceNames": [],
        "natureTypes": [],
        "eduLevel": "",
        "categories": [],
        "features": [],
        "pageIndex": 1,
        "pageSize": 20,
        "sort": 11
		}, 
  	uri = '/youzy.dms.basiclib.api.college.query'


exports123 = function(e, r) {
    if (null == e)
        throw new Error("Illegal argument " + e);
    var n = t.wordsToBytes(a(e, r));
    return r && r.asBytes ? n : r && r.asString ? o.bytesToString(n) : t.bytesToHex(n)
}

// 将a改为data
o = Object.keys(data).length > 0 ? "".concat(JSON.stringify(data), "&").concat(i) : "&".concat(i);
o = o.toLowerCase()

console.log(exports123(o))

执行发现t未定义,进入t
image.png
image.png
跳转到到wordsToBytes在r中,即t为r,将r复制出来并改名r123,并将t.wordsToBytes改为r123.wordsToBytes

r123 = {
  rotl: function(e, t) {
    return e << t | e >>> 32 - t
  },
  rotr: function(e, t) {
    return e << 32 - t | e >>> t
  },
  endian: function(e) {
    if (e.constructor == Number)
      return 16711935 & r123.rotl(e, 8) | 4278255360 & r123.rotl(e, 24);
    for (var t = 0; t < e.length; t++)
      e[t] = r123.endian(e[t]);
    return e
  },
  randomBytes: function(e) {
    for (var t = []; e > 0; e--)
      t.push(Math.floor(256 * Math.random()));
    return t
  },
  bytesToWords: function(e) {
    for (var t = [], r = 0, n = 0; r < e.length; r++,
         n += 8)
      t[n >>> 5] |= e[r] << 24 - n % 32;
    return t
  },
  wordsToBytes: function(e) {
    for (var t = [], r = 0; r < 32 * e.length; r += 8)
      t.push(e[r >>> 5] >>> 24 - r % 32 & 255);
    return t
  },
  bytesToHex: function(e) {
    for (var t = [], r = 0; r < e.length; r++)
      t.push((e[r] >>> 4).toString(16)),
        t.push((15 & e[r]).toString(16));
    return t.join("")
  },
  hexToBytes: function(e) {
    for (var t = [], r = 0; r < e.length; r += 2)
      t.push(parseInt(e.substr(r, 2), 16));
    return t
  },
  bytesToBase64: function(e) {
    for (var r = [], n = 0; n < e.length; n += 3)
      for (var i = e[n] << 16 | e[n + 1] << 8 | e[n + 2], o = 0; o < 4; o++)
        8 * n + 6 * o <= 8 * e.length ? r.push(t.charAt(i >>> 6 * (3 - o) & 63)) : r.push("=");
    return r.join("")
  },
  base64ToBytes: function(e) {
    e = e.replace(/[^A-Z0-9+\/]/gi, "");
    for (var r = [], n = 0, i = 0; n < e.length; i = ++n % 4)
      0 != i && r.push((t.indexOf(e.charAt(n - 1)) & Math.pow(2, -2 * i + 8) - 1) << 2 * i | t.indexOf(e.charAt(n)) >>> 6 - 2 * i);
    return r
  }
}

此时我们的js文件为

var i = "9SASji5OWnG41iRKiSvTJHlXHmRySRp1",
data = {
    "keyword": "",
    "provinceNames": [],
    "natureTypes": [],
    "eduLevel": "",
    "categories": [],
    "features": [],
    "pageIndex": 1,
    "pageSize": 20,
    "sort": 11
}, uri = '/youzy.dms.basiclib.api.college.query'
exports123 = function(e, r) {
    if (null == e)
        throw new Error("Illegal argument " + e);
    var n = r123.wordsToBytes(a(e, r));
    return r && r.asBytes ? n : r && r.asString ? o.bytesToString(n) : t.bytesToHex(n)
}

//t
r123 = {
    rotl: function(e, t) {
        return e << t | e >>> 32 - t
    },
    rotr: function(e, t) {
        return e << 32 - t | e >>> t
    },
    endian: function(e) {
        if (e.constructor == Number)
            return 16711935 & r123.rotl(e, 8) | 4278255360 & r123.rotl(e, 24);
        for (var t = 0; t < e.length; t++)
            e[t] = r123.endian(e[t]);
        return e
    },
    randomBytes: function(e) {
        for (var t = []; e > 0; e--)
            t.push(Math.floor(256 * Math.random()));
        return t
    },
    bytesToWords: function(e) {
        for (var t = [], r = 0, n = 0; r < e.length; r++,
            n += 8)
            t[n >>> 5] |= e[r] << 24 - n % 32;
        return t
    },
    wordsToBytes: function(e) {
        for (var t = [], r = 0; r < 32 * e.length; r += 8)
            t.push(e[r >>> 5] >>> 24 - r % 32 & 255);
        return t
    },
    bytesToHex: function(e) {
        for (var t = [], r = 0; r < e.length; r++)
            t.push((e[r] >>> 4).toString(16)),
                t.push((15 & e[r]).toString(16));
        return t.join("")
    },
    hexToBytes: function(e) {
        for (var t = [], r = 0; r < e.length; r += 2)
            t.push(parseInt(e.substr(r, 2), 16));
        return t
    },
    bytesToBase64: function(e) {
        for (var r = [], n = 0; n < e.length; n += 3)
            for (var i = e[n] << 16 | e[n + 1] << 8 | e[n + 2], o = 0; o < 4; o++)
                8 * n + 6 * o <= 8 * e.length ? r.push(t.charAt(i >>> 6 * (3 - o) & 63)) : r.push("=");
        return r.join("")
    },
    base64ToBytes: function(e) {
        e = e.replace(/[^A-Z0-9+\/]/gi, "");
        for (var r = [], n = 0, i = 0; n < e.length; i = ++n % 4)
            0 != i && r.push((t.indexOf(e.charAt(n - 1)) & Math.pow(2, -2 * i + 8) - 1) << 2 * i | t.indexOf(e.charAt(n)) >>> 6 - 2 * i);
        return r
    }
}

o = Object.keys(data).length > 0 ? "".concat(JSON.stringify(data), "&").concat(i) : "&".concat(i);
o = o.toLowerCase()

console.log(exports123(o))

执行提示a未定义

image.png

进入a并将a复制出来,改名123,替换其中的t.bytesToWords为r123.bytesToWords,t.endianr为123.endian

a123 = function(e, r) {
    e.constructor == String ? e = r && "binary" === r.encoding ? o.stringToBytes(e) : n.stringToBytes(e) : i(e) ? e = Array.prototype.slice.call(e, 0) : Array.isArray(e) || e.constructor === Uint8Array || (e = e.toString());
    for (var s = r123.bytesToWords(e), u = 8 * e.length, c = 1732584193, f = -271733879, d = -1732584194, l = 271733878, h = 0; h < s.length; h++)
        s[h] = 16711935 & (s[h] << 8 | s[h] >>> 24) | 4278255360 & (s[h] << 24 | s[h] >>> 8);
    s[u >>> 5] |= 128 << u % 32,
        s[14 + (u + 64 >>> 9 << 4)] = u;
    var p = a._ff
        , b = a._gg
        , y = a._hh
        , m = a._ii;
    for (h = 0; h < s.length; h += 16) {
        var g = c
            , v = f
            , _ = d
            , w = l;
        c = p(c, f, d, l, s[h + 0], 7, -680876936),
            l = p(l, c, f, d, s[h + 1], 12, -389564586),
            d = p(d, l, c, f, s[h + 2], 17, 606105819),
            f = p(f, d, l, c, s[h + 3], 22, -1044525330),
            c = p(c, f, d, l, s[h + 4], 7, -176418897),
            l = p(l, c, f, d, s[h + 5], 12, 1200080426),
            d = p(d, l, c, f, s[h + 6], 17, -1473231341),
            f = p(f, d, l, c, s[h + 7], 22, -45705983),
            c = p(c, f, d, l, s[h + 8], 7, 1770035416),
            l = p(l, c, f, d, s[h + 9], 12, -1958414417),
            d = p(d, l, c, f, s[h + 10], 17, -42063),
            f = p(f, d, l, c, s[h + 11], 22, -1990404162),
            c = p(c, f, d, l, s[h + 12], 7, 1804603682),
            l = p(l, c, f, d, s[h + 13], 12, -40341101),
            d = p(d, l, c, f, s[h + 14], 17, -1502002290),
            c = b(c, f = p(f, d, l, c, s[h + 15], 22, 1236535329), d, l, s[h + 1], 5, -165796510),
            l = b(l, c, f, d, s[h + 6], 9, -1069501632),
            d = b(d, l, c, f, s[h + 11], 14, 643717713),
            f = b(f, d, l, c, s[h + 0], 20, -373897302),
            c = b(c, f, d, l, s[h + 5], 5, -701558691),
            l = b(l, c, f, d, s[h + 10], 9, 38016083),
            d = b(d, l, c, f, s[h + 15], 14, -660478335),
            f = b(f, d, l, c, s[h + 4], 20, -405537848),
            c = b(c, f, d, l, s[h + 9], 5, 568446438),
            l = b(l, c, f, d, s[h + 14], 9, -1019803690),
            d = b(d, l, c, f, s[h + 3], 14, -187363961),
            f = b(f, d, l, c, s[h + 8], 20, 1163531501),
            c = b(c, f, d, l, s[h + 13], 5, -1444681467),
            l = b(l, c, f, d, s[h + 2], 9, -51403784),
            d = b(d, l, c, f, s[h + 7], 14, 1735328473),
            c = y(c, f = b(f, d, l, c, s[h + 12], 20, -1926607734), d, l, s[h + 5], 4, -378558),
            l = y(l, c, f, d, s[h + 8], 11, -2022574463),
            d = y(d, l, c, f, s[h + 11], 16, 1839030562),
            f = y(f, d, l, c, s[h + 14], 23, -35309556),
            c = y(c, f, d, l, s[h + 1], 4, -1530992060),
            l = y(l, c, f, d, s[h + 4], 11, 1272893353),
            d = y(d, l, c, f, s[h + 7], 16, -155497632),
            f = y(f, d, l, c, s[h + 10], 23, -1094730640),
            c = y(c, f, d, l, s[h + 13], 4, 681279174),
            l = y(l, c, f, d, s[h + 0], 11, -358537222),
            d = y(d, l, c, f, s[h + 3], 16, -722521979),
            f = y(f, d, l, c, s[h + 6], 23, 76029189),
            c = y(c, f, d, l, s[h + 9], 4, -640364487),
            l = y(l, c, f, d, s[h + 12], 11, -421815835),
            d = y(d, l, c, f, s[h + 15], 16, 530742520),
            c = m(c, f = y(f, d, l, c, s[h + 2], 23, -995338651), d, l, s[h + 0], 6, -198630844),
            l = m(l, c, f, d, s[h + 7], 10, 1126891415),
            d = m(d, l, c, f, s[h + 14], 15, -1416354905),
            f = m(f, d, l, c, s[h + 5], 21, -57434055),
            c = m(c, f, d, l, s[h + 12], 6, 1700485571),
            l = m(l, c, f, d, s[h + 3], 10, -1894986606),
            d = m(d, l, c, f, s[h + 10], 15, -1051523),
            f = m(f, d, l, c, s[h + 1], 21, -2054922799),
            c = m(c, f, d, l, s[h + 8], 6, 1873313359),
            l = m(l, c, f, d, s[h + 15], 10, -30611744),
            d = m(d, l, c, f, s[h + 6], 15, -1560198380),
            f = m(f, d, l, c, s[h + 13], 21, 1309151649),
            c = m(c, f, d, l, s[h + 4], 6, -145523070),
            l = m(l, c, f, d, s[h + 11], 10, -1120210379),
            d = m(d, l, c, f, s[h + 2], 15, 718787259),
            f = m(f, d, l, c, s[h + 9], 21, -343485551),
            c = c + g >>> 0,
            f = f + v >>> 0,
            d = d + _ >>> 0,
            l = l + w >>> 0
    }
    return r123.endian([c, f, d, l])
}

继续发现n未定义
image.png
进入n
image.png

将n复制出来,改名n123

var n123 = {
            utf8: {
                stringToBytes: function(e) {
                    return n123.bin.stringToBytes(unescape(encodeURIComponent(e)))
                },
                bytesToString: function(e) {
                    return decodeURIComponent(escape(r.bin.bytesToString(e)))
                }
            },
            bin: {
                stringToBytes: function(e) {
                    for (var t = [], r = 0; r < e.length; r++)
                        t.push(255 & e.charCodeAt(r));
                    return t
                },
                bytesToString: function(e) {
                    for (var t = [], r = 0; r < e.length; r++)
                        t.push(String.fromCharCode(e[r]));
                    return t.join("")
                }
            }
        }
  • 将a123调用的地方修改为n123.utf8,即n.stringToBytes(e)改为n123.utf8.stringToBytes(e)

继续运行发现a123的缺少以下这些方法

image.png
复制出来改造下

_ff = function(e, t, r, n, i, o, a) {
  var s = e + (t & r | ~t & n) + (i >>> 0) + a;
  return (s << o | s >>> 32 - o) + t
}
_gg = function(e, t, r, n, i, o, a) {
  var s = e + (t & n | r & ~n) + (i >>> 0) + a;
  return (s << o | s >>> 32 - o) + t
}
_hh = function(e, t, r, n, i, o, a) {
  var s = e + (t ^ r ^ n) + (i >>> 0) + a;
  return (s << o | s >>> 32 - o) + t
}
_ii = function(e, t, r, n, i, o, a) {
  var s = e + (r ^ (t | ~n)) + (i >>> 0) + a;
  return (s << o | s >>> 32 - o) + t
}

完整的a方法

// a
a123 = function(e, r) {
    e.constructor == String ? e = r && "binary" === r.encoding ? o.stringToBytes(e) : n123.utf8.stringToBytes(e) : i(e) ? e = Array.prototype.slice.call(e, 0) : Array.isArray(e) || e.constructor === Uint8Array || (e = e.toString());
    for (var s = r123.bytesToWords(e), u = 8 * e.length, c = 1732584193, f = -271733879, d = -1732584194, l = 271733878, h = 0; h < s.length; h++)
        s[h] = 16711935 & (s[h] << 8 | s[h] >>> 24) | 4278255360 & (s[h] << 24 | s[h] >>> 8);
    s[u >>> 5] |= 128 << u % 32,
        s[14 + (u + 64 >>> 9 << 4)] = u;
    var p = _ff
        , b = _gg
        , y = _hh
        , m = _ii;
    for (h = 0; h < s.length; h += 16) {
        var g = c
            , v = f
            , _ = d
            , w = l;
        c = p(c, f, d, l, s[h + 0], 7, -680876936),
            l = p(l, c, f, d, s[h + 1], 12, -389564586),
            d = p(d, l, c, f, s[h + 2], 17, 606105819),
            f = p(f, d, l, c, s[h + 3], 22, -1044525330),
            c = p(c, f, d, l, s[h + 4], 7, -176418897),
            l = p(l, c, f, d, s[h + 5], 12, 1200080426),
            d = p(d, l, c, f, s[h + 6], 17, -1473231341),
            f = p(f, d, l, c, s[h + 7], 22, -45705983),
            c = p(c, f, d, l, s[h + 8], 7, 1770035416),
            l = p(l, c, f, d, s[h + 9], 12, -1958414417),
            d = p(d, l, c, f, s[h + 10], 17, -42063),
            f = p(f, d, l, c, s[h + 11], 22, -1990404162),
            c = p(c, f, d, l, s[h + 12], 7, 1804603682),
            l = p(l, c, f, d, s[h + 13], 12, -40341101),
            d = p(d, l, c, f, s[h + 14], 17, -1502002290),
            c = b(c, f = p(f, d, l, c, s[h + 15], 22, 1236535329), d, l, s[h + 1], 5, -165796510),
            l = b(l, c, f, d, s[h + 6], 9, -1069501632),
            d = b(d, l, c, f, s[h + 11], 14, 643717713),
            f = b(f, d, l, c, s[h + 0], 20, -373897302),
            c = b(c, f, d, l, s[h + 5], 5, -701558691),
            l = b(l, c, f, d, s[h + 10], 9, 38016083),
            d = b(d, l, c, f, s[h + 15], 14, -660478335),
            f = b(f, d, l, c, s[h + 4], 20, -405537848),
            c = b(c, f, d, l, s[h + 9], 5, 568446438),
            l = b(l, c, f, d, s[h + 14], 9, -1019803690),
            d = b(d, l, c, f, s[h + 3], 14, -187363961),
            f = b(f, d, l, c, s[h + 8], 20, 1163531501),
            c = b(c, f, d, l, s[h + 13], 5, -1444681467),
            l = b(l, c, f, d, s[h + 2], 9, -51403784),
            d = b(d, l, c, f, s[h + 7], 14, 1735328473),
            c = y(c, f = b(f, d, l, c, s[h + 12], 20, -1926607734), d, l, s[h + 5], 4, -378558),
            l = y(l, c, f, d, s[h + 8], 11, -2022574463),
            d = y(d, l, c, f, s[h + 11], 16, 1839030562),
            f = y(f, d, l, c, s[h + 14], 23, -35309556),
            c = y(c, f, d, l, s[h + 1], 4, -1530992060),
            l = y(l, c, f, d, s[h + 4], 11, 1272893353),
            d = y(d, l, c, f, s[h + 7], 16, -155497632),
            f = y(f, d, l, c, s[h + 10], 23, -1094730640),
            c = y(c, f, d, l, s[h + 13], 4, 681279174),
            l = y(l, c, f, d, s[h + 0], 11, -358537222),
            d = y(d, l, c, f, s[h + 3], 16, -722521979),
            f = y(f, d, l, c, s[h + 6], 23, 76029189),
            c = y(c, f, d, l, s[h + 9], 4, -640364487),
            l = y(l, c, f, d, s[h + 12], 11, -421815835),
            d = y(d, l, c, f, s[h + 15], 16, 530742520),
            c = m(c, f = y(f, d, l, c, s[h + 2], 23, -995338651), d, l, s[h + 0], 6, -198630844),
            l = m(l, c, f, d, s[h + 7], 10, 1126891415),
            d = m(d, l, c, f, s[h + 14], 15, -1416354905),
            f = m(f, d, l, c, s[h + 5], 21, -57434055),
            c = m(c, f, d, l, s[h + 12], 6, 1700485571),
            l = m(l, c, f, d, s[h + 3], 10, -1894986606),
            d = m(d, l, c, f, s[h + 10], 15, -1051523),
            f = m(f, d, l, c, s[h + 1], 21, -2054922799),
            c = m(c, f, d, l, s[h + 8], 6, 1873313359),
            l = m(l, c, f, d, s[h + 15], 10, -30611744),
            d = m(d, l, c, f, s[h + 6], 15, -1560198380),
            f = m(f, d, l, c, s[h + 13], 21, 1309151649),
            c = m(c, f, d, l, s[h + 4], 6, -145523070),
            l = m(l, c, f, d, s[h + 11], 10, -1120210379),
            d = m(d, l, c, f, s[h + 2], 15, 718787259),
            f = m(f, d, l, c, s[h + 9], 21, -343485551),
            c = c + g >>> 0,
            f = f + v >>> 0,
            d = d + _ >>> 0,
            l = l + w >>> 0
    }
    return r123.endian([c, f, d, l])
}
_ff = function(e, t, r, n, i, o, a) {
    var s = e + (t & r | ~t & n) + (i >>> 0) + a;
    return (s << o | s >>> 32 - o) + t
}
_gg = function(e, t, r, n, i, o, a) {
        var s = e + (t & n | r & ~n) + (i >>> 0) + a;
        return (s << o | s >>> 32 - o) + t
    }
_hh = function(e, t, r, n, i, o, a) {
        var s = e + (t ^ r ^ n) + (i >>> 0) + a;
        return (s << o | s >>> 32 - o) + t
    }
_ii = function(e, t, r, n, i, o, a) {
        var s = e + (r ^ (t | ~n)) + (i >>> 0) + a;
        return (s << o | s >>> 32 - o) + t
    }
  • 继续执行exports123提示缺少t,将t.bytesToHex改为r123.bytesToHex即可

完整的js代码

var i = "9SASji5OWnG41iRKiSvTJHlXHmRySRp1",
    data = {
        "keyword": "",
        "provinceNames": [],
        "natureTypes": [],
        "eduLevel": "",
        "categories": [],
        "features": [],
        "pageIndex": 1,
        "pageSize": 20,
        "sort": 11
    }, uri = '/youzy.dms.basiclib.api.college.query'
exports123 = function (e, r) {
    if (null == e)
        throw new Error("Illegal argument " + e);
    var n = r123.wordsToBytes(a123(e, r));
    return r && r.asBytes ? n : r && r.asString ? o.bytesToString(n) : r123.bytesToHex(n)
}

// n
var n123 = {
    utf8: {
        stringToBytes: function (e) {
            return n123.bin.stringToBytes(unescape(encodeURIComponent(e)))
        },
        bytesToString: function (e) {
            return decodeURIComponent(escape(r.bin.bytesToString(e)))
        }
    },
    bin: {
        stringToBytes: function (e) {
            for (var t = [], r = 0; r < e.length; r++)
                t.push(255 & e.charCodeAt(r));
            return t
        },
        bytesToString: function (e) {
            for (var t = [], r = 0; r < e.length; r++)
                t.push(String.fromCharCode(e[r]));
            return t.join("")
        }
    }
}

//t
r123 = {
    rotl: function (e, t) {
        return e << t | e >>> 32 - t
    },
    rotr: function (e, t) {
        return e << 32 - t | e >>> t
    },
    endian: function (e) {
        if (e.constructor == Number)
            return 16711935 & r123.rotl(e, 8) | 4278255360 & r123.rotl(e, 24);
        for (var t = 0; t < e.length; t++)
            e[t] = r123.endian(e[t]);
        return e
    },
    randomBytes: function (e) {
        for (var t = []; e > 0; e--)
            t.push(Math.floor(256 * Math.random()));
        return t
    },
    bytesToWords: function (e) {
        for (var t = [], r = 0, n = 0; r < e.length; r++,
            n += 8)
            t[n >>> 5] |= e[r] << 24 - n % 32;
        return t
    },
    wordsToBytes: function (e) {
        for (var t = [], r = 0; r < 32 * e.length; r += 8)
            t.push(e[r >>> 5] >>> 24 - r % 32 & 255);
        return t
    },
    bytesToHex: function (e) {
        for (var t = [], r = 0; r < e.length; r++)
            t.push((e[r] >>> 4).toString(16)),
                t.push((15 & e[r]).toString(16));
        return t.join("")
    },
    hexToBytes: function (e) {
        for (var t = [], r = 0; r < e.length; r += 2)
            t.push(parseInt(e.substr(r, 2), 16));
        return t
    },
    bytesToBase64: function (e) {
        for (var r = [], n = 0; n < e.length; n += 3)
            for (var i = e[n] << 16 | e[n + 1] << 8 | e[n + 2], o = 0; o < 4; o++)
                8 * n + 6 * o <= 8 * e.length ? r.push(t.charAt(i >>> 6 * (3 - o) & 63)) : r.push("=");
        return r.join("")
    },
    base64ToBytes: function (e) {
        e = e.replace(/[^A-Z0-9+\/]/gi, "");
        for (var r = [], n = 0, i = 0; n < e.length; i = ++n % 4)
            0 != i && r.push((t.indexOf(e.charAt(n - 1)) & Math.pow(2, -2 * i + 8) - 1) << 2 * i | t.indexOf(e.charAt(n)) >>> 6 - 2 * i);
        return r
    }
}

// a
a123 = function (e, r) {
    e.constructor == String ? e = r && "binary" === r.encoding ? o.stringToBytes(e) : n123.utf8.stringToBytes(e) : i(e) ? e = Array.prototype.slice.call(e, 0) : Array.isArray(e) || e.constructor === Uint8Array || (e = e.toString());
    for (var s = r123.bytesToWords(e), u = 8 * e.length, c = 1732584193, f = -271733879, d = -1732584194, l = 271733878, h = 0; h < s.length; h++)
        s[h] = 16711935 & (s[h] << 8 | s[h] >>> 24) | 4278255360 & (s[h] << 24 | s[h] >>> 8);
    s[u >>> 5] |= 128 << u % 32,
        s[14 + (u + 64 >>> 9 << 4)] = u;
    var p = _ff
        , b = _gg
        , y = _hh
        , m = _ii;
    for (h = 0; h < s.length; h += 16) {
        var g = c
            , v = f
            , _ = d
            , w = l;
        c = p(c, f, d, l, s[h + 0], 7, -680876936),
            l = p(l, c, f, d, s[h + 1], 12, -389564586),
            d = p(d, l, c, f, s[h + 2], 17, 606105819),
            f = p(f, d, l, c, s[h + 3], 22, -1044525330),
            c = p(c, f, d, l, s[h + 4], 7, -176418897),
            l = p(l, c, f, d, s[h + 5], 12, 1200080426),
            d = p(d, l, c, f, s[h + 6], 17, -1473231341),
            f = p(f, d, l, c, s[h + 7], 22, -45705983),
            c = p(c, f, d, l, s[h + 8], 7, 1770035416),
            l = p(l, c, f, d, s[h + 9], 12, -1958414417),
            d = p(d, l, c, f, s[h + 10], 17, -42063),
            f = p(f, d, l, c, s[h + 11], 22, -1990404162),
            c = p(c, f, d, l, s[h + 12], 7, 1804603682),
            l = p(l, c, f, d, s[h + 13], 12, -40341101),
            d = p(d, l, c, f, s[h + 14], 17, -1502002290),
            c = b(c, f = p(f, d, l, c, s[h + 15], 22, 1236535329), d, l, s[h + 1], 5, -165796510),
            l = b(l, c, f, d, s[h + 6], 9, -1069501632),
            d = b(d, l, c, f, s[h + 11], 14, 643717713),
            f = b(f, d, l, c, s[h + 0], 20, -373897302),
            c = b(c, f, d, l, s[h + 5], 5, -701558691),
            l = b(l, c, f, d, s[h + 10], 9, 38016083),
            d = b(d, l, c, f, s[h + 15], 14, -660478335),
            f = b(f, d, l, c, s[h + 4], 20, -405537848),
            c = b(c, f, d, l, s[h + 9], 5, 568446438),
            l = b(l, c, f, d, s[h + 14], 9, -1019803690),
            d = b(d, l, c, f, s[h + 3], 14, -187363961),
            f = b(f, d, l, c, s[h + 8], 20, 1163531501),
            c = b(c, f, d, l, s[h + 13], 5, -1444681467),
            l = b(l, c, f, d, s[h + 2], 9, -51403784),
            d = b(d, l, c, f, s[h + 7], 14, 1735328473),
            c = y(c, f = b(f, d, l, c, s[h + 12], 20, -1926607734), d, l, s[h + 5], 4, -378558),
            l = y(l, c, f, d, s[h + 8], 11, -2022574463),
            d = y(d, l, c, f, s[h + 11], 16, 1839030562),
            f = y(f, d, l, c, s[h + 14], 23, -35309556),
            c = y(c, f, d, l, s[h + 1], 4, -1530992060),
            l = y(l, c, f, d, s[h + 4], 11, 1272893353),
            d = y(d, l, c, f, s[h + 7], 16, -155497632),
            f = y(f, d, l, c, s[h + 10], 23, -1094730640),
            c = y(c, f, d, l, s[h + 13], 4, 681279174),
            l = y(l, c, f, d, s[h + 0], 11, -358537222),
            d = y(d, l, c, f, s[h + 3], 16, -722521979),
            f = y(f, d, l, c, s[h + 6], 23, 76029189),
            c = y(c, f, d, l, s[h + 9], 4, -640364487),
            l = y(l, c, f, d, s[h + 12], 11, -421815835),
            d = y(d, l, c, f, s[h + 15], 16, 530742520),
            c = m(c, f = y(f, d, l, c, s[h + 2], 23, -995338651), d, l, s[h + 0], 6, -198630844),
            l = m(l, c, f, d, s[h + 7], 10, 1126891415),
            d = m(d, l, c, f, s[h + 14], 15, -1416354905),
            f = m(f, d, l, c, s[h + 5], 21, -57434055),
            c = m(c, f, d, l, s[h + 12], 6, 1700485571),
            l = m(l, c, f, d, s[h + 3], 10, -1894986606),
            d = m(d, l, c, f, s[h + 10], 15, -1051523),
            f = m(f, d, l, c, s[h + 1], 21, -2054922799),
            c = m(c, f, d, l, s[h + 8], 6, 1873313359),
            l = m(l, c, f, d, s[h + 15], 10, -30611744),
            d = m(d, l, c, f, s[h + 6], 15, -1560198380),
            f = m(f, d, l, c, s[h + 13], 21, 1309151649),
            c = m(c, f, d, l, s[h + 4], 6, -145523070),
            l = m(l, c, f, d, s[h + 11], 10, -1120210379),
            d = m(d, l, c, f, s[h + 2], 15, 718787259),
            f = m(f, d, l, c, s[h + 9], 21, -343485551),
            c = c + g >>> 0,
            f = f + v >>> 0,
            d = d + _ >>> 0,
            l = l + w >>> 0
    }
    return r123.endian([c, f, d, l])
}
_ff = function (e, t, r, n, i, o, a) {
    var s = e + (t & r | ~t & n) + (i >>> 0) + a;
    return (s << o | s >>> 32 - o) + t
}
_gg = function (e, t, r, n, i, o, a) {
    var s = e + (t & n | r & ~n) + (i >>> 0) + a;
    return (s << o | s >>> 32 - o) + t
}
_hh = function (e, t, r, n, i, o, a) {
    var s = e + (t ^ r ^ n) + (i >>> 0) + a;
    return (s << o | s >>> 32 - o) + t
}
_ii = function (e, t, r, n, i, o, a) {
    var s = e + (r ^ (t | ~n)) + (i >>> 0) + a;
    return (s << o | s >>> 32 - o) + t
}

o = Object.keys(data).length > 0 ? "".concat(JSON.stringify(data), "&").concat(i) : "&".concat(i);
o = o.toLowerCase()

console.log(exports123(o))

java调用

js封装方法提供java调用

function sign(data){
    data =  JSON.parse(data)
    o = Object.keys(data).length > 0 ? "".concat(JSON.stringify(data), "&").concat(i) : "&".concat(i);
    o = o.toLowerCase()
    return exports123(o)
}

java代码示例

package com.wq;

import cn.hutool.http.HttpUtil;


import javax.script.Invocable;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.HashMap;
import java.util.Map;

/**
 * @Description TODO
 * @Version 1.0.0
 * @Date 2023/7/13
 * @Author wandaren
 */
public class TestMain {
    public static void main(String[] args) throws ScriptException, FileNotFoundException, NoSuchMethodException {
        int pageIndex = 1;
        String url = "https://uwf7de983aad7a717eb.youzy.cn/youzy.dms.basiclib.api.college.query";
        String i = "/youzy.dms.basiclib.api.college.query";
        String data = "{\"keyword\":\"\",\"provinceNames\":[],\"natureTypes\":[],\"eduLevel\":\"\",\"categories\":[],\"features\":[],\"pageIndex\":"+pageIndex+",\"pageSize\":20,\"sort\":11}";

        BufferedReader buf =  new BufferedReader(new InputStreamReader(
                        new FileInputStream("/Users/wandaren/Downloads/Compressed/zktest/src/test/java/com/wq/youzy.js"), StandardCharsets.UTF_8));
        // 获取JS执行引擎
        ScriptEngineManager scriptManager = new ScriptEngineManager();
            ScriptEngine js = scriptManager.getEngineByExtension("js");
            js.eval(buf);
            Invocable inv = (Invocable) js;
        String sign = (String) inv.invokeFunction("sign", data,i);
        System.out.println(sign);

            Map<String,String> map = new HashMap<>();
                map.put("Accept", "*/*");
                map.put("Accept-Language", "zh-CN,zh;q=0.9,en;q=0.8");
                map.put("Connection", "keep-alive");
                map.put("Content-Type", "application/json");
                map.put("Host", "uwf7de983aad7a717eb.youzy.cn");
                map.put("Origin", "https://pv4y-pc.youzy.cn");
                map.put("Referer", "https://pv4y-pc.youzy.cn/");
                map.put("Sec-Fetch-Dest", "empty");
                map.put("Sec-Fetch-Mode", "cors");
                map.put("Sec-Fetch-Site", "same-site");
                map.put("User-Agent", "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36");
                map.put("sec-ch-ua", "\"Not.A/Brand\";v=\"8\", \"Chromium\";v=\"114\", \"Google Chrome\";v=\"114\"");
                map.put("sec-ch-ua-mobile", "?0");
                map.put("sec-ch-ua-platform", "\"macOS\"");
                map.put("u-sign", sign+"");
                map.put("u-token", "");
        final String body = HttpUtil
                .createPost(url)
                .addHeaders(map)
                .body(data)
                .execute()
                .body();
        System.out.println(body);


    }
}
posted @ 2023-08-09 23:03  花开重日  阅读(122)  评论(0编辑  收藏  举报