某志愿网js逆向

发布时间 2023-08-09 23:10:43作者: 花开重日

逆向过程分析与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);


  }
}