123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- function SM4(e, t, n) {
- var i = 0
- , o = 32
- , a = 16
- , s = [214, 144, 233, 254, 204, 225, 61, 183, 22, 182, 20, 194, 40, 251, 44, 5, 43, 103, 154, 118, 42, 190, 4, 195, 170, 68, 19, 38, 73, 134, 6, 153, 156, 66, 80, 244, 145, 239, 152, 122, 51, 84, 11, 67, 237, 207, 172, 98, 228, 179, 28, 169, 201, 8, 232, 149, 128, 223, 148, 250, 117, 143, 63, 166, 71, 7, 167, 252, 243, 115, 23, 186, 131, 89, 60, 25, 230, 133, 79, 168, 104, 107, 129, 178, 113, 100, 218, 139, 248, 235, 15, 75, 112, 86, 157, 53, 30, 36, 14, 94, 99, 88, 209, 162, 37, 34, 124, 59, 1, 33, 120, 135, 212, 0, 70, 87, 159, 211, 39, 82, 76, 54, 2, 231, 160, 196, 200, 158, 234, 191, 138, 210, 64, 199, 56, 181, 163, 247, 242, 206, 249, 97, 21, 161, 224, 174, 93, 164, 155, 52, 26, 85, 173, 147, 50, 48, 245, 140, 177, 227, 29, 246, 226, 46, 130, 102, 202, 96, 192, 41, 35, 171, 13, 83, 78, 111, 213, 219, 55, 69, 222, 253, 142, 47, 3, 255, 106, 114, 109, 108, 91, 81, 141, 27, 175, 146, 187, 221, 188, 127, 17, 217, 92, 65, 31, 16, 90, 216, 10, 193, 49, 136, 165, 205, 123, 189, 45, 116, 208, 18, 184, 229, 180, 176, 137, 105, 151, 74, 12, 150, 119, 126, 101, 185, 241, 9, 197, 110, 198, 132, 24, 240, 125, 236, 58, 220, 77, 32, 121, 238, 95, 62, 215, 203, 57, 72]
- , u = [462357, 472066609, 943670861, 1415275113, 1886879365, 2358483617, 2830087869, 3301692121, 3773296373, 4228057617, 404694573, 876298825, 1347903077, 1819507329, 2291111581, 2762715833, 3234320085, 3705924337, 4177462797, 337322537, 808926789, 1280531041, 1752135293, 2223739545, 2695343797, 3166948049, 3638552301, 4110090761, 269950501, 741554753, 1213159005, 1684763257];
- function c(t) {
- for (var e = [], n = 0, r = t.length; n < r; n += 2)
- e.push(parseInt(t.substr(n, 2), 16));
- return e
- }
- function f(t) {
- return t.map((function (t) {
- return t = t.toString(16),
- 1 === t.length ? "0" + t : t
- }
- )).join("")
- }
- function l(t) {
- for (var e = [], n = 0, r = t.length; n < r; n++) {
- var i = t.charCodeAt(n);
- if (i <= 127)
- e.push(i);
- else if (i <= 2047)
- e.push(192 | i >>> 6),
- e.push(128 | 63 & i);
- else if (i <= 55295 || i >= 57344 && i <= 65535)
- e.push(224 | i >>> 12),
- e.push(128 | i >>> 6 & 63),
- e.push(128 | 63 & i);
- else {
- if (!(i >= 65536 && i <= 1114111))
- throw e.push(i),
- new Error("input is not supported");
- n++,
- e.push(240 | i >>> 18 & 28),
- e.push(128 | i >>> 12 & 63),
- e.push(128 | i >>> 6 & 63),
- e.push(128 | 63 & i)
- }
- }
- return e
- }
- function h(t) {
- for (var e = [], n = 0, r = t.length; n < r; n++)
- t[n] >= 240 && t[n] <= 247 ? (e.push(String.fromCharCode(((7 & t[n]) << 18) + ((63 & t[n + 1]) << 12) + ((63 & t[n + 2]) << 6) + (63 & t[n + 3]))),
- n += 3) : t[n] >= 224 && t[n] <= 239 ? (e.push(String.fromCharCode(((15 & t[n]) << 12) + ((63 & t[n + 1]) << 6) + (63 & t[n + 2]))),
- n += 2) : t[n] >= 192 && t[n] <= 223 ? (e.push(String.fromCharCode(((31 & t[n]) << 6) + (63 & t[n + 1]))),
- n++) : e.push(String.fromCharCode(t[n]));
- return e.join("")
- }
- function d(t, e) {
- return t << e | t >>> 32 - e
- }
- function p(t) {
- return (255 & s[t >>> 24 & 255]) << 24 | (255 & s[t >>> 16 & 255]) << 16 | (255 & s[t >>> 8 & 255]) << 8 | 255 & s[255 & t]
- }
- function v(t) {
- return t ^ d(t, 2) ^ d(t, 10) ^ d(t, 18) ^ d(t, 24)
- }
- function y(t) {
- return t ^ d(t, 13) ^ d(t, 23)
- }
- function g(t, e, n) {
- for (var r = new Array(4), i = new Array(4), o = 0; o < 4; o++)
- i[0] = 255 & t[0 + 4 * o],
- i[1] = 255 & t[1 + 4 * o],
- i[2] = 255 & t[2 + 4 * o],
- i[3] = 255 & t[3 + 4 * o],
- r[o] = i[0] << 24 | i[1] << 16 | i[2] << 8 | i[3];
- for (var a, s = 0; s < 32; s += 4)
- a = r[1] ^ r[2] ^ r[3] ^ n[s + 0],
- r[0] ^= v(p(a)),
- a = r[2] ^ r[3] ^ r[0] ^ n[s + 1],
- r[1] ^= v(p(a)),
- a = r[3] ^ r[0] ^ r[1] ^ n[s + 2],
- r[2] ^= v(p(a)),
- a = r[0] ^ r[1] ^ r[2] ^ n[s + 3],
- r[3] ^= v(p(a));
- for (var u = 0; u < 16; u += 4)
- e[u] = r[3 - u / 4] >>> 24 & 255,
- e[u + 1] = r[3 - u / 4] >>> 16 & 255,
- e[u + 2] = r[3 - u / 4] >>> 8 & 255,
- e[u + 3] = 255 & r[3 - u / 4]
- }
- function m(t, e, n) {
- for (var r = new Array(4), o = new Array(4), a = 0; a < 4; a++)
- o[0] = 255 & t[0 + 4 * a],
- o[1] = 255 & t[1 + 4 * a],
- o[2] = 255 & t[2 + 4 * a],
- o[3] = 255 & t[3 + 4 * a],
- r[a] = o[0] << 24 | o[1] << 16 | o[2] << 8 | o[3];
- r[0] ^= 2746333894,
- r[1] ^= 1453994832,
- r[2] ^= 1736282519,
- r[3] ^= 2993693404;
- for (var s, c = 0; c < 32; c += 4)
- s = r[1] ^ r[2] ^ r[3] ^ u[c + 0],
- e[c + 0] = r[0] ^= y(p(s)),
- s = r[2] ^ r[3] ^ r[0] ^ u[c + 1],
- e[c + 1] = r[1] ^= y(p(s)),
- s = r[3] ^ r[0] ^ r[1] ^ u[c + 2],
- e[c + 2] = r[2] ^= y(p(s)),
- s = r[0] ^ r[1] ^ r[2] ^ u[c + 3],
- e[c + 3] = r[3] ^= y(p(s));
- if (n === i)
- for (var f, l = 0; l < 16; l++)
- f = e[l],
- e[l] = e[31 - l],
- e[31 - l] = f
- }
- function b(t, e, n) {
- var s = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : {}
- , u = s.padding
- , d = void 0 === u ? "pkcs#5" : u
- , p = (s.mode,
- s.output)
- , v = void 0 === p ? "string" : p;
- if ("string" === typeof e && (e = c(e)),
- 16 !== e.length)
- throw new Error("key is invalid");
- if (t = "string" === typeof t ? n !== i ? l(t) : c(t) : r(t),
- "pkcs#5" === d && n !== i)
- for (var y = a - t.length % a, b = 0; b < y; b++)
- t.push(y);
- var _ = new Array(o);
- m(e, _, n);
- var w = []
- , x = t.length
- , k = 0;
- while (x >= a) {
- var A = t.slice(k, k + 16)
- , S = new Array(16);
- g(A, S, _);
- for (var O = 0; O < a; O++)
- w[k + O] = S[O];
- x -= a,
- k += a
- }
- if ("pkcs#5" === d && n === i) {
- var E = w[w.length - 1];
- w.splice(w.length - E, E)
- }
- return "array" !== v ? n !== i ? f(w) : h(w) : w
- }
- return b(e, t, n);
- };
- w = "dt!Ppb9t"
- function sl(e) {
- for (var n = "", A = 0; A < e.length; A++)
- "" === n ? n = e.charCodeAt(A).toString(16) : n += e.charCodeAt(A).toString(16);
- return n
- }
- function sdate(e) {
- var n = {
- "M+": new Date().getMonth() + 1,
- "d+": new Date().getDate(),
- "h+": new Date().getHours() % 12 == 0 ? 12 : new Date().getHours() % 12,
- "H+": new Date().getHours(),
- "m+": new Date().getMinutes(),
- "s+": new Date().getSeconds(),
- "q+": Math.floor((new Date().getMonth() + 3) / 3),
- S: new Date().getMilliseconds()
- }
- , A = {
- 0: "日",
- 1: "一",
- 2: "二",
- 3: "三",
- 4: "四",
- 5: "五",
- 6: "六"
- };
- for (var t in /(y+)/.test(e) && (e = e.replace(RegExp.$1, (new Date().getFullYear() + "").substr(4 - RegExp.$1.length))),
- /(E+)/.test(e) && (e = e.replace(RegExp.$1, (RegExp.$1.length > 1 ? RegExp.$1.length > 2 ? "星期" : "周" : "") + A[new Date().getDay() + ""])),
- n)
- new RegExp("(" + t + ")").test(e) && (e = e.replace(RegExp.$1, 1 == RegExp.$1.length ? n[t] : ("00" + n[t]).substr(("" + n[t]).length)));
- return e
- }
- function signature(n, t) {
- var K = [
- "/auth/oauth2/getPublicKey",
- "/auth/white/sendSm4",
- "/auth/user/logout",
- "/auth/user/checklogin",
- "/auth/qrcode/verifyQRCode",
- "/auth/message/sendSmsCode",
- "/auth/oauth2/revokeToken",
- "/auth/white/getAreCode",
- "/auth/white/getSecondAuthInfo",
- "/auth/oauth2/checkRedirectUrl",
- "/auth/message/captchaImage"
- ]
- var p = {},
- l = "";
- p["zipCode"] = "0";
- u = t;
- c = u.substring(0, 8) + w;
- "post" === n.method && (K.indexOf(n.url) !== -1 ? (p["encryptCode"] = "0",
- p.datagram = JSON.stringify(n.data)) : (P = JSON.stringify(n.data),
- l = SM4(P, sl(c), 1),
- p.datagram = l,
- p["encryptCode"] = "2"));
- p["timestamp"] = sdate("yyyyMMddHHmmss");
- p["access_token"] = "";
- p["signtype"] = "HMacSHA256";
- p["signature"] = CryptoJS.HmacSHA256(p["zipCode"] + p["encryptCode"] + l + p["timestamp"] + p["signtype"], u).toString(CryptoJS.enc.Hex);
- return p
- }
- function responseParse(n, new_key16) {
- if ("2" === n.encryptCode) {
- var t = new_key16.substring(0, 8) + w;
- n.datagram = SM4(n.datagram, sl(t), 0)
- }
- return n
- }
- function clientId(e) {
- for (var n = e.indexOf("?") + 1, A = e.substr(n), t = A.split("&"), f = {}, v = 0; v < t.length; v++) {
- var r = t[v].split("=")
- , d = r[0]
- , p = r[1];
- f[d] = p
- }
- return f
- }
|