某招聘网站搜索结果接口逆向之webpack扣取

逆向网址

aHR0cHM6Ly93ZS41MWpvYi5jb20v


逆向链接

aHR0cHM6Ly93ZS41MWpvYi5jb20vcGMvc2VhcmNoP2pvYkFyZWE9MDAwMDAwJmtleXdvcmQ9cGhwJnNlYXJjaFR5cGU9MiZrZXl3b3JkVHlwZT0=


逆向接口 

aHR0cHM6Ly93ZS41MWpvYi5jb20vYXBpL2pvYi9zZWFyY2gtcGM=

逆向过程 

请求方式

        POST

逆向参数

请求头中携带的参数:

Sign:  e788afa0154865676022085afb586fd907886b3db9943678c54821eb91a1665f

Uuid: d4d34656b36efcf40a8077696cde033a

过程分析

根据XHR断点方式可快速进入发包内容

跟栈到如下位置处

设置条件断后释放掉xhr断点

e.url.indexOf( '/api/job/search-pc' ) != -1

 断点处开始跟栈, 到如下位置发现为 异步

发现关键点:

m.interceptors.request.use((function(t) {
	var e = t.url + (t.data || "");
	return t.headers.sign = g.a.HmacSHA256(e, c["a"].state.commonStore.cupid_sign_key),
	t.headers["uuid"] = u["b"].getuuid(),
	t.headers["From-Domain"] = c["a"].state.commonStore.fromdomain,
	t.headers["account-id"] = localStorage.getItem("accountId") || "",
	t.headers["user-token"] = localStorage.getItem("token") || "",
	t.headers["partner"] = c["a"].state.commonStore.partner,
	t.headers["property"] = encodeURIComponent(JSON.stringify(Object(o["a"])(Object(o["a"])({}, u["b"].getProperty()), t.property || {}))),
	t
}
// headers -> sign
t.headers.sign = g.a.HmacSHA256(e, c["a"].state.commonStore.cupid_sign_key)


// headers -> uuid
t.headers["uuid"] = u["b"].getuuid(),

 

如果发现跟栈之后没找到设置请求头的位置,那么这时候试试搜索大法 发现请求头中还存在其他参数:

User-Token,Property,Partner,From-Domain....

这里以【User-Token】为例

在这三个位置打上断点刷新页面调试也可定位到上述位关键点位置

由关键词HmacSHA256可知为SHA-256生成哈希值的HMAC算法

验证可知为标准加密

代码扣取

UUID

x = function() {
	if (d["a"].state.commonStore.uuid)
		return d["a"].state.commonStore.uuid;
	var e = (new Date).getTime().toString()
	  , t = e + parseInt(1e7 * Math.random().toString().slice(0, 9)).toString();
	return d["a"].commit("commonStore/setValueLocalStorage", {
		uuid: t
	}),
	t
}


  简化版
var e = (new Date).getTime().toString()
	, t = e + parseInt(1e7 * Math.random().toString().slice(0, 9)).toString();
return  t

Sign

进入方式

8429: function (e, t, n) {
	(function (i) {
			var r, a, o, s = n("7037").default;
			n("c73d"),
				n("6c57"),
				n("ace4"),
				n("d3b7"),
				n("fb2c"),
				n("907a"),
				n("9a8c"),
				n("a975"),
				n("735e"),
				n("c1ac"),
				n("d139"),
				n("3a7b"),
				n("986a"),
				n("1d02"),
				n("d5d6"),
				n("82f8"),
				n("e91f"),
				n("60bd"),
				n("5f96"),
				n("3280"),
				n("3fcc"),
				n("ca91"),
				n("25a1"),
				n("cd26"),
				n("3c5d"),
				n("2954"),
				n("649e"),
				n("219c"),
				n("170b"),
				n("b39a"),
				n("6ce5"),
				n("2834"),
				n("72f7"),
				n("4ea1"),
				n("d9e2"),
				n("25f0"),
				n("fb6a"),
				n("14d9"),
				n("a15b"),
				n("99af"),
				n("a434"),
				n("c19f"),
				n("5cc6"),
				n("fd87"),
				n("8a59"),
				n("8b09"),
				n("84c3"),
				n("143c"),
				n("cfc3"),
				n("4a9b"),
				function (n, i) {
					"object" === s(t) ? e.exports = t = i() : (a = [],
						r = i,
						o = "function" === typeof r ? r.apply(t, a) : r,
					void 0 === o || (e.exports = o))
				}(0, (function () {
						var e = e || function (e, t) {
							var r;
							if ("undefined" !== typeof window && window.crypto && (r = window.crypto),
							"undefined" !== typeof self && self.crypto && (r = self.crypto),
							"undefined" !== typeof globalThis && globalThis.crypto && (r = globalThis.crypto),
							!r && "undefined" !== typeof window && window.msCrypto && (r = window.msCrypto),
							!r && "undefined" !== typeof i && i.crypto && (r = i.crypto),
								!r)
								try {
									r = {}
								} catch (v) {
								}
							var a = function () {
								if (r) {
									if ("function" === typeof r.getRandomValues)
										try {
											return r.getRandomValues(new Uint32Array(1))[0]
										} catch (v) {
										}
									if ("function" === typeof r.randomBytes)
										try {
											return r.randomBytes(4).readInt32LE()
										} catch (v) {
										}
								}
								throw new Error("Native crypto module could not be used to get secure random number.")
							}
								, o = Object.create || function () {
								function e() {
								}

								return function (t) {
									var n;
									return e.prototype = t,
										n = new e,
										e.prototype = null,
										n
								}
							}()
								, s = {}
								, c = s.lib = {}
								, l = c.Base = function () {
								return {
									extend: function (e) {
										var t = o(this);
										return e && t.mixIn(e),
										t.hasOwnProperty("init") && this.init !== t.init || (t.init = function () {
												t.$super.init.apply(this, arguments)
											}
										),
											t.init.prototype = t,
											t.$super = this,
											t
									},
									create: function () {
										var e = this.extend();
										return e.init.apply(e, arguments),
											e
									},
									init: function () {
									},
									mixIn: function (e) {
										for (var t in e)
											e.hasOwnProperty(t) && (this[t] = e[t]);
										e.hasOwnProperty("toString") && (this.toString = e.toString)
									},
									clone: function () {
										return this.init.prototype.extend(this)
									}
								}
							}()
								, u = c.WordArray = l.extend({
								init: function (e, n) {
									e = this.words = e || [],
										this.sigBytes = n != t ? n : 4 * e.length
								},
								toString: function (e) {
									return (e || f).stringify(this)
								},
								concat: function (e) {
									var t = this.words
										, n = e.words
										, i = this.sigBytes
										, r = e.sigBytes;
									if (this.clamp(),
									i % 4)
										for (var a = 0; a < r; a++) {
											var o = n[a >>> 2] >>> 24 - a % 4 * 8 & 255;
											t[i + a >>> 2] |= o << 24 - (i + a) % 4 * 8
										}
									else
										for (var s = 0; s < r; s += 4)
											t[i + s >>> 2] = n[s >>> 2];
									return this.sigBytes += r,
										this
								},
								clamp: function () {
									var t = this.words
										, n = this.sigBytes;
									t[n >>> 2] &= 4294967295 << 32 - n % 4 * 8,
										t.length = e.ceil(n / 4)
								},
								clone: function () {
									var e = l.clone.call(this);
									return e.words = this.words.slice(0),
										e
								},
								random: function (e) {
									for (var t = [], n = 0; n < e; n += 4)
										t.push(a());
									return new u.init(t, e)
								}
							})
								, d = s.enc = {}
								, f = d.Hex = {
								stringify: function (e) {
									for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r++) {
										var a = t[r >>> 2] >>> 24 - r % 4 * 8 & 255;
										i.push((a >>> 4).toString(16)),
											i.push((15 & a).toString(16))
									}
									return i.join("")
								},
								parse: function (e) {
									for (var t = e.length, n = [], i = 0; i < t; i += 2)
										n[i >>> 3] |= parseInt(e.substr(i, 2), 16) << 24 - i % 8 * 4;
									return new u.init(n, t / 2)
								}
							}
								, h = d.Latin1 = {
								stringify: function (e) {
									for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r++) {
										var a = t[r >>> 2] >>> 24 - r % 4 * 8 & 255;
										i.push(String.fromCharCode(a))
									}
									return i.join("")
								},
								parse: function (e) {
									for (var t = e.length, n = [], i = 0; i < t; i++)
										n[i >>> 2] |= (255 & e.charCodeAt(i)) << 24 - i % 4 * 8;
									return new u.init(n, t)
								}
							}
								, A = d.Utf8 = {
								stringify: function (e) {
									try {
										return decodeURIComponent(escape(h.stringify(e)))
									} catch (t) {
										throw new Error("Malformed UTF-8 data")
									}
								},
								parse: function (e) {
									return h.parse(unescape(encodeURIComponent(e)))
								}
							}
								, p = c.BufferedBlockAlgorithm = l.extend({
								reset: function () {
									this._data = new u.init,
										this._nDataBytes = 0
								},
								_append: function (e) {
									"string" == typeof e && (e = A.parse(e)),
										this._data.concat(e),
										this._nDataBytes += e.sigBytes
								},
								_process: function (t) {
									var n, i = this._data, r = i.words, a = i.sigBytes, o = this.blockSize,
										s = 4 * o, c = a / s;
									c = t ? e.ceil(c) : e.max((0 | c) - this._minBufferSize, 0);
									var l = c * o
										, d = e.min(4 * l, a);
									if (l) {
										for (var f = 0; f < l; f += o)
											this._doProcessBlock(r, f);
										n = r.splice(0, l),
											i.sigBytes -= d
									}
									return new u.init(n, d)
								},
								clone: function () {
									var e = l.clone.call(this);
									return e._data = this._data.clone(),
										e
								},
								_minBufferSize: 0
							})
								, g = (c.Hasher = p.extend({
								cfg: l.extend(),
								init: function (e) {
									this.cfg = this.cfg.extend(e),
										this.reset()
								},
								reset: function () {
									p.reset.call(this),
										this._doReset()
								},
								update: function (e) {
									return this._append(e),
										this._process(),
										this
								},
								finalize: function (e) {
									e && this._append(e);
									var t = this._doFinalize();
									return t
								},
								blockSize: 16,
								_createHelper: function (e) {
									return function (t, n) {
										return new e.init(n).finalize(t)
									}
								},
								_createHmacHelper: function (e) {
									return function (t, n) {
										return new g.HMAC.init(e, n).finalize(t)
									}
								}
							}),
								s.algo = {});
							return s
						}(Math);
						return function (t) {
							var n = e
								, i = n.lib
								, r = i.Base
								, a = i.WordArray
								, o = n.x64 = {};
							o.Word = r.extend({
								init: function (e, t) {
									this.high = e,
										this.low = t
								}
							}),
								o.WordArray = r.extend({
									init: function (e, n) {
										e = this.words = e || [],
											this.sigBytes = n != t ? n : 8 * e.length
									},
									toX32: function () {
										for (var e = this.words, t = e.length, n = [], i = 0; i < t; i++) {
											var r = e[i];
											n.push(r.high),
												n.push(r.low)
										}
										return a.create(n, this.sigBytes)
									},
									clone: function () {
										for (var e = r.clone.call(this), t = e.words = this.words.slice(0), n = t.length, i = 0; i < n; i++)
											t[i] = t[i].clone();
										return e
									}
								})
						}(),
							function () {
								if ("function" == typeof ArrayBuffer) {
									var t = e
										, n = t.lib
										, i = n.WordArray
										, r = i.init
										, a = i.init = function (e) {
											if (e instanceof ArrayBuffer && (e = new Uint8Array(e)),
											(e instanceof Int8Array || "undefined" !== typeof Uint8ClampedArray && e instanceof Uint8ClampedArray || e instanceof Int16Array || e instanceof Uint16Array || e instanceof Int32Array || e instanceof Uint32Array || e instanceof Float32Array || e instanceof Float64Array) && (e = new Uint8Array(e.buffer, e.byteOffset, e.byteLength)),
											e instanceof Uint8Array) {
												for (var t = e.byteLength, n = [], i = 0; i < t; i++)
													n[i >>> 2] |= e[i] << 24 - i % 4 * 8;
												r.call(this, n, t)
											} else
												r.apply(this, arguments)
										}
									;
									a.prototype = i
								}
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = t.enc;
								r.Utf16 = r.Utf16BE = {
									stringify: function (e) {
										for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r += 2) {
											var a = t[r >>> 2] >>> 16 - r % 4 * 8 & 65535;
											i.push(String.fromCharCode(a))
										}
										return i.join("")
									},
									parse: function (e) {
										for (var t = e.length, n = [], r = 0; r < t; r++)
											n[r >>> 1] |= e.charCodeAt(r) << 16 - r % 2 * 16;
										return i.create(n, 2 * t)
									}
								};

								function a(e) {
									return e << 8 & 4278255360 | e >>> 8 & 16711935
								}

								r.Utf16LE = {
									stringify: function (e) {
										for (var t = e.words, n = e.sigBytes, i = [], r = 0; r < n; r += 2) {
											var o = a(t[r >>> 2] >>> 16 - r % 4 * 8 & 65535);
											i.push(String.fromCharCode(o))
										}
										return i.join("")
									},
									parse: function (e) {
										for (var t = e.length, n = [], r = 0; r < t; r++)
											n[r >>> 1] |= a(e.charCodeAt(r) << 16 - r % 2 * 16);
										return i.create(n, 2 * t)
									}
								}
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = t.enc;
								r.Base64 = {
									stringify: function (e) {
										var t = e.words
											, n = e.sigBytes
											, i = this._map;
										e.clamp();
										for (var r = [], a = 0; a < n; a += 3)
											for (var o = t[a >>> 2] >>> 24 - a % 4 * 8 & 255, s = t[a + 1 >>> 2] >>> 24 - (a + 1) % 4 * 8 & 255, c = t[a + 2 >>> 2] >>> 24 - (a + 2) % 4 * 8 & 255, l = o << 16 | s << 8 | c, u = 0; u < 4 && a + .75 * u < n; u++)
												r.push(i.charAt(l >>> 6 * (3 - u) & 63));
										var d = i.charAt(64);
										if (d)
											while (r.length % 4)
												r.push(d);
										return r.join("")
									},
									parse: function (e) {
										var t = e.length
											, n = this._map
											, i = this._reverseMap;
										if (!i) {
											i = this._reverseMap = [];
											for (var r = 0; r < n.length; r++)
												i[n.charCodeAt(r)] = r
										}
										var o = n.charAt(64);
										if (o) {
											var s = e.indexOf(o);
											-1 !== s && (t = s)
										}
										return a(e, t, i)
									},
									_map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="
								};

								function a(e, t, n) {
									for (var r = [], a = 0, o = 0; o < t; o++)
										if (o % 4) {
											var s = n[e.charCodeAt(o - 1)] << o % 4 * 2
												, c = n[e.charCodeAt(o)] >>> 6 - o % 4 * 2
												, l = s | c;
											r[a >>> 2] |= l << 24 - a % 4 * 8,
												a++
										}
									return i.create(r, a)
								}
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = t.enc;
								r.Base64url = {
									stringify: function (e) {
										var t = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1]
											, n = e.words
											, i = e.sigBytes
											, r = t ? this._safe_map : this._map;
										e.clamp();
										for (var a = [], o = 0; o < i; o += 3)
											for (var s = n[o >>> 2] >>> 24 - o % 4 * 8 & 255, c = n[o + 1 >>> 2] >>> 24 - (o + 1) % 4 * 8 & 255, l = n[o + 2 >>> 2] >>> 24 - (o + 2) % 4 * 8 & 255, u = s << 16 | c << 8 | l, d = 0; d < 4 && o + .75 * d < i; d++)
												a.push(r.charAt(u >>> 6 * (3 - d) & 63));
										var f = r.charAt(64);
										if (f)
											while (a.length % 4)
												a.push(f);
										return a.join("")
									},
									parse: function (e) {
										var t = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1]
											, n = e.length
											, i = t ? this._safe_map : this._map
											, r = this._reverseMap;
										if (!r) {
											r = this._reverseMap = [];
											for (var o = 0; o < i.length; o++)
												r[i.charCodeAt(o)] = o
										}
										var s = i.charAt(64);
										if (s) {
											var c = e.indexOf(s);
											-1 !== c && (n = c)
										}
										return a(e, n, r)
									},
									_map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
									_safe_map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"
								};

								function a(e, t, n) {
									for (var r = [], a = 0, o = 0; o < t; o++)
										if (o % 4) {
											var s = n[e.charCodeAt(o - 1)] << o % 4 * 2
												, c = n[e.charCodeAt(o)] >>> 6 - o % 4 * 2
												, l = s | c;
											r[a >>> 2] |= l << 24 - a % 4 * 8,
												a++
										}
									return i.create(r, a)
								}
							}(),
							function (t) {
								var n = e
									, i = n.lib
									, r = i.WordArray
									, a = i.Hasher
									, o = n.algo
									, s = [];
								(function () {
										for (var e = 0; e < 64; e++)
											s[e] = 4294967296 * t.abs(t.sin(e + 1)) | 0
									}
								)();
								var c = o.MD5 = a.extend({
									_doReset: function () {
										this._hash = new r.init([1732584193, 4023233417, 2562383102, 271733878])
									},
									_doProcessBlock: function (e, t) {
										for (var n = 0; n < 16; n++) {
											var i = t + n
												, r = e[i];
											e[i] = 16711935 & (r << 8 | r >>> 24) | 4278255360 & (r << 24 | r >>> 8)
										}
										var a = this._hash.words
											, o = e[t + 0]
											, c = e[t + 1]
											, h = e[t + 2]
											, A = e[t + 3]
											, p = e[t + 4]
											, g = e[t + 5]
											, v = e[t + 6]
											, m = e[t + 7]
											, y = e[t + 8]
											, b = e[t + 9]
											, _ = e[t + 10]
											, w = e[t + 11]
											, x = e[t + 12]
											, k = e[t + 13]
											, S = e[t + 14]
											, C = e[t + 15]
											, B = a[0]
											, L = a[1]
											, M = a[2]
											, O = a[3];
										B = l(B, L, M, O, o, 7, s[0]),
											O = l(O, B, L, M, c, 12, s[1]),
											M = l(M, O, B, L, h, 17, s[2]),
											L = l(L, M, O, B, A, 22, s[3]),
											B = l(B, L, M, O, p, 7, s[4]),
											O = l(O, B, L, M, g, 12, s[5]),
											M = l(M, O, B, L, v, 17, s[6]),
											L = l(L, M, O, B, m, 22, s[7]),
											B = l(B, L, M, O, y, 7, s[8]),
											O = l(O, B, L, M, b, 12, s[9]),
											M = l(M, O, B, L, _, 17, s[10]),
											L = l(L, M, O, B, w, 22, s[11]),
											B = l(B, L, M, O, x, 7, s[12]),
											O = l(O, B, L, M, k, 12, s[13]),
											M = l(M, O, B, L, S, 17, s[14]),
											L = l(L, M, O, B, C, 22, s[15]),
											B = u(B, L, M, O, c, 5, s[16]),
											O = u(O, B, L, M, v, 9, s[17]),
											M = u(M, O, B, L, w, 14, s[18]),
											L = u(L, M, O, B, o, 20, s[19]),
											B = u(B, L, M, O, g, 5, s[20]),
											O = u(O, B, L, M, _, 9, s[21]),
											M = u(M, O, B, L, C, 14, s[22]),
											L = u(L, M, O, B, p, 20, s[23]),
											B = u(B, L, M, O, b, 5, s[24]),
											O = u(O, B, L, M, S, 9, s[25]),
											M = u(M, O, B, L, A, 14, s[26]),
											L = u(L, M, O, B, y, 20, s[27]),
											B = u(B, L, M, O, k, 5, s[28]),
											O = u(O, B, L, M, h, 9, s[29]),
											M = u(M, O, B, L, m, 14, s[30]),
											L = u(L, M, O, B, x, 20, s[31]),
											B = d(B, L, M, O, g, 4, s[32]),
											O = d(O, B, L, M, y, 11, s[33]),
											M = d(M, O, B, L, w, 16, s[34]),
											L = d(L, M, O, B, S, 23, s[35]),
											B = d(B, L, M, O, c, 4, s[36]),
											O = d(O, B, L, M, p, 11, s[37]),
											M = d(M, O, B, L, m, 16, s[38]),
											L = d(L, M, O, B, _, 23, s[39]),
											B = d(B, L, M, O, k, 4, s[40]),
											O = d(O, B, L, M, o, 11, s[41]),
											M = d(M, O, B, L, A, 16, s[42]),
											L = d(L, M, O, B, v, 23, s[43]),
											B = d(B, L, M, O, b, 4, s[44]),
											O = d(O, B, L, M, x, 11, s[45]),
											M = d(M, O, B, L, C, 16, s[46]),
											L = d(L, M, O, B, h, 23, s[47]),
											B = f(B, L, M, O, o, 6, s[48]),
											O = f(O, B, L, M, m, 10, s[49]),
											M = f(M, O, B, L, S, 15, s[50]),
											L = f(L, M, O, B, g, 21, s[51]),
											B = f(B, L, M, O, x, 6, s[52]),
											O = f(O, B, L, M, A, 10, s[53]),
											M = f(M, O, B, L, _, 15, s[54]),
											L = f(L, M, O, B, c, 21, s[55]),
											B = f(B, L, M, O, y, 6, s[56]),
											O = f(O, B, L, M, C, 10, s[57]),
											M = f(M, O, B, L, v, 15, s[58]),
											L = f(L, M, O, B, k, 21, s[59]),
											B = f(B, L, M, O, p, 6, s[60]),
											O = f(O, B, L, M, w, 10, s[61]),
											M = f(M, O, B, L, h, 15, s[62]),
											L = f(L, M, O, B, b, 21, s[63]),
											a[0] = a[0] + B | 0,
											a[1] = a[1] + L | 0,
											a[2] = a[2] + M | 0,
											a[3] = a[3] + O | 0
									},
									_doFinalize: function () {
										var e = this._data
											, n = e.words
											, i = 8 * this._nDataBytes
											, r = 8 * e.sigBytes;
										n[r >>> 5] |= 128 << 24 - r % 32;
										var a = t.floor(i / 4294967296)
											, o = i;
										n[15 + (r + 64 >>> 9 << 4)] = 16711935 & (a << 8 | a >>> 24) | 4278255360 & (a << 24 | a >>> 8),
											n[14 + (r + 64 >>> 9 << 4)] = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8),
											e.sigBytes = 4 * (n.length + 1),
											this._process();
										for (var s = this._hash, c = s.words, l = 0; l < 4; l++) {
											var u = c[l];
											c[l] = 16711935 & (u << 8 | u >>> 24) | 4278255360 & (u << 24 | u >>> 8)
										}
										return s
									},
									clone: function () {
										var e = a.clone.call(this);
										return e._hash = this._hash.clone(),
											e
									}
								});

								function l(e, t, n, i, r, a, o) {
									var s = e + (t & n | ~t & i) + r + o;
									return (s << a | s >>> 32 - a) + t
								}

								function u(e, t, n, i, r, a, o) {
									var s = e + (t & i | n & ~i) + r + o;
									return (s << a | s >>> 32 - a) + t
								}

								function d(e, t, n, i, r, a, o) {
									var s = e + (t ^ n ^ i) + r + o;
									return (s << a | s >>> 32 - a) + t
								}

								function f(e, t, n, i, r, a, o) {
									var s = e + (n ^ (t | ~i)) + r + o;
									return (s << a | s >>> 32 - a) + t
								}

								n.MD5 = a._createHelper(c),
									n.HmacMD5 = a._createHmacHelper(c)
							}(Math),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = n.Hasher
									, a = t.algo
									, o = []
									, s = a.SHA1 = r.extend({
									_doReset: function () {
										this._hash = new i.init([1732584193, 4023233417, 2562383102, 271733878, 3285377520])
									},
									_doProcessBlock: function (e, t) {
										for (var n = this._hash.words, i = n[0], r = n[1], a = n[2], s = n[3], c = n[4], l = 0; l < 80; l++) {
											if (l < 16)
												o[l] = 0 | e[t + l];
											else {
												var u = o[l - 3] ^ o[l - 8] ^ o[l - 14] ^ o[l - 16];
												o[l] = u << 1 | u >>> 31
											}
											var d = (i << 5 | i >>> 27) + c + o[l];
											d += l < 20 ? 1518500249 + (r & a | ~r & s) : l < 40 ? 1859775393 + (r ^ a ^ s) : l < 60 ? (r & a | r & s | a & s) - 1894007588 : (r ^ a ^ s) - 899497514,
												c = s,
												s = a,
												a = r << 30 | r >>> 2,
												r = i,
												i = d
										}
										n[0] = n[0] + i | 0,
											n[1] = n[1] + r | 0,
											n[2] = n[2] + a | 0,
											n[3] = n[3] + s | 0,
											n[4] = n[4] + c | 0
									},
									_doFinalize: function () {
										var e = this._data
											, t = e.words
											, n = 8 * this._nDataBytes
											, i = 8 * e.sigBytes;
										return t[i >>> 5] |= 128 << 24 - i % 32,
											t[14 + (i + 64 >>> 9 << 4)] = Math.floor(n / 4294967296),
											t[15 + (i + 64 >>> 9 << 4)] = n,
											e.sigBytes = 4 * t.length,
											this._process(),
											this._hash
									},
									clone: function () {
										var e = r.clone.call(this);
										return e._hash = this._hash.clone(),
											e
									}
								});
								t.SHA1 = r._createHelper(s),
									t.HmacSHA1 = r._createHmacHelper(s)
							}(),
							function (t) {
								var n = e
									, i = n.lib
									, r = i.WordArray
									, a = i.Hasher
									, o = n.algo
									, s = []
									, c = [];
								(function () {
										function e(e) {
											for (var n = t.sqrt(e), i = 2; i <= n; i++)
												if (!(e % i))
													return !1;
											return !0
										}

										function n(e) {
											return 4294967296 * (e - (0 | e)) | 0
										}

										var i = 2
											, r = 0;
										while (r < 64)
											e(i) && (r < 8 && (s[r] = n(t.pow(i, .5))),
												c[r] = n(t.pow(i, 1 / 3)),
												r++),
												i++
									}
								)();
								var l = []
									, u = o.SHA256 = a.extend({
									_doReset: function () {
										this._hash = new r.init(s.slice(0))
									},
									_doProcessBlock: function (e, t) {
										for (var n = this._hash.words, i = n[0], r = n[1], a = n[2], o = n[3], s = n[4], u = n[5], d = n[6], f = n[7], h = 0; h < 64; h++) {
											if (h < 16)
												l[h] = 0 | e[t + h];
											else {
												var A = l[h - 15]
													, p = (A << 25 | A >>> 7) ^ (A << 14 | A >>> 18) ^ A >>> 3
													, g = l[h - 2]
													, v = (g << 15 | g >>> 17) ^ (g << 13 | g >>> 19) ^ g >>> 10;
												l[h] = p + l[h - 7] + v + l[h - 16]
											}
											var m = s & u ^ ~s & d
												, y = i & r ^ i & a ^ r & a
												,
												b = (i << 30 | i >>> 2) ^ (i << 19 | i >>> 13) ^ (i << 10 | i >>> 22)
												,
												_ = (s << 26 | s >>> 6) ^ (s << 21 | s >>> 11) ^ (s << 7 | s >>> 25)
												, w = f + _ + m + c[h] + l[h]
												, x = b + y;
											f = d,
												d = u,
												u = s,
												s = o + w | 0,
												o = a,
												a = r,
												r = i,
												i = w + x | 0
										}
										n[0] = n[0] + i | 0,
											n[1] = n[1] + r | 0,
											n[2] = n[2] + a | 0,
											n[3] = n[3] + o | 0,
											n[4] = n[4] + s | 0,
											n[5] = n[5] + u | 0,
											n[6] = n[6] + d | 0,
											n[7] = n[7] + f | 0
									},
									_doFinalize: function () {
										var e = this._data
											, n = e.words
											, i = 8 * this._nDataBytes
											, r = 8 * e.sigBytes;
										return n[r >>> 5] |= 128 << 24 - r % 32,
											n[14 + (r + 64 >>> 9 << 4)] = t.floor(i / 4294967296),
											n[15 + (r + 64 >>> 9 << 4)] = i,
											e.sigBytes = 4 * n.length,
											this._process(),
											this._hash
									},
									clone: function () {
										var e = a.clone.call(this);
										return e._hash = this._hash.clone(),
											e
									}
								});
								n.SHA256 = a._createHelper(u),
									n.HmacSHA256 = a._createHmacHelper(u)
							}(Math),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = t.algo
									, a = r.SHA256
									, o = r.SHA224 = a.extend({
									_doReset: function () {
										this._hash = new i.init([3238371032, 914150663, 812702999, 4144912697, 4290775857, 1750603025, 1694076839, 3204075428])
									},
									_doFinalize: function () {
										var e = a._doFinalize.call(this);
										return e.sigBytes -= 4,
											e
									}
								});
								t.SHA224 = a._createHelper(o),
									t.HmacSHA224 = a._createHmacHelper(o)
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.Hasher
									, r = t.x64
									, a = r.Word
									, o = r.WordArray
									, s = t.algo;

								function c() {
									return a.create.apply(a, arguments)
								}

								var l = [c(1116352408, 3609767458), c(1899447441, 602891725), c(3049323471, 3964484399), c(3921009573, 2173295548), c(961987163, 4081628472), c(1508970993, 3053834265), c(2453635748, 2937671579), c(2870763221, 3664609560), c(3624381080, 2734883394), c(310598401, 1164996542), c(607225278, 1323610764), c(1426881987, 3590304994), c(1925078388, 4068182383), c(2162078206, 991336113), c(2614888103, 633803317), c(3248222580, 3479774868), c(3835390401, 2666613458), c(4022224774, 944711139), c(264347078, 2341262773), c(604807628, 2007800933), c(770255983, 1495990901), c(1249150122, 1856431235), c(1555081692, 3175218132), c(1996064986, 2198950837), c(2554220882, 3999719339), c(2821834349, 766784016), c(2952996808, 2566594879), c(3210313671, 3203337956), c(3336571891, 1034457026), c(3584528711, 2466948901), c(113926993, 3758326383), c(338241895, 168717936), c(666307205, 1188179964), c(773529912, 1546045734), c(1294757372, 1522805485), c(1396182291, 2643833823), c(1695183700, 2343527390), c(1986661051, 1014477480), c(2177026350, 1206759142), c(2456956037, 344077627), c(2730485921, 1290863460), c(2820302411, 3158454273), c(3259730800, 3505952657), c(3345764771, 106217008), c(3516065817, 3606008344), c(3600352804, 1432725776), c(4094571909, 1467031594), c(275423344, 851169720), c(430227734, 3100823752), c(506948616, 1363258195), c(659060556, 3750685593), c(883997877, 3785050280), c(958139571, 3318307427), c(1322822218, 3812723403), c(1537002063, 2003034995), c(1747873779, 3602036899), c(1955562222, 1575990012), c(2024104815, 1125592928), c(2227730452, 2716904306), c(2361852424, 442776044), c(2428436474, 593698344), c(2756734187, 3733110249), c(3204031479, 2999351573), c(3329325298, 3815920427), c(3391569614, 3928383900), c(3515267271, 566280711), c(3940187606, 3454069534), c(4118630271, 4000239992), c(116418474, 1914138554), c(174292421, 2731055270), c(289380356, 3203993006), c(460393269, 320620315), c(685471733, 587496836), c(852142971, 1086792851), c(1017036298, 365543100), c(1126000580, 2618297676), c(1288033470, 3409855158), c(1501505948, 4234509866), c(1607167915, 987167468), c(1816402316, 1246189591)]
									, u = [];
								(function () {
										for (var e = 0; e < 80; e++)
											u[e] = c()
									}
								)();
								var d = s.SHA512 = i.extend({
									_doReset: function () {
										this._hash = new o.init([new a.init(1779033703, 4089235720), new a.init(3144134277, 2227873595), new a.init(1013904242, 4271175723), new a.init(2773480762, 1595750129), new a.init(1359893119, 2917565137), new a.init(2600822924, 725511199), new a.init(528734635, 4215389547), new a.init(1541459225, 327033209)])
									},
									_doProcessBlock: function (e, t) {
										for (var n = this._hash.words, i = n[0], r = n[1], a = n[2], o = n[3], s = n[4], c = n[5], d = n[6], f = n[7], h = i.high, A = i.low, p = r.high, g = r.low, v = a.high, m = a.low, y = o.high, b = o.low, _ = s.high, w = s.low, x = c.high, k = c.low, S = d.high, C = d.low, B = f.high, L = f.low, M = h, O = A, E = p, T = g, j = v, D = m, F = y, I = b, P = _, N = w, U = x, H = k, R = S, V = C, Y = B, Q = L, z = 0; z < 80; z++) {
											var q, $, W = u[z];
											if (z < 16)
												$ = W.high = 0 | e[t + 2 * z],
													q = W.low = 0 | e[t + 2 * z + 1];
											else {
												var G = u[z - 15]
													, K = G.high
													, J = G.low
													, X = (K >>> 1 | J << 31) ^ (K >>> 8 | J << 24) ^ K >>> 7
													,
													Z = (J >>> 1 | K << 31) ^ (J >>> 8 | K << 24) ^ (J >>> 7 | K << 25)
													, ee = u[z - 2]
													, te = ee.high
													, ne = ee.low
													, ie = (te >>> 19 | ne << 13) ^ (te << 3 | ne >>> 29) ^ te >>> 6
													,
													re = (ne >>> 19 | te << 13) ^ (ne << 3 | te >>> 29) ^ (ne >>> 6 | te << 26)
													, ae = u[z - 7]
													, oe = ae.high
													, se = ae.low
													, ce = u[z - 16]
													, le = ce.high
													, ue = ce.low;
												q = Z + se,
													$ = X + oe + (q >>> 0 < Z >>> 0 ? 1 : 0),
													q += re,
													$ = $ + ie + (q >>> 0 < re >>> 0 ? 1 : 0),
													q += ue,
													$ = $ + le + (q >>> 0 < ue >>> 0 ? 1 : 0),
													W.high = $,
													W.low = q
											}
											var de = P & U ^ ~P & R
												, fe = N & H ^ ~N & V
												, he = M & E ^ M & j ^ E & j
												, Ae = O & T ^ O & D ^ T & D
												,
												pe = (M >>> 28 | O << 4) ^ (M << 30 | O >>> 2) ^ (M << 25 | O >>> 7)
												,
												ge = (O >>> 28 | M << 4) ^ (O << 30 | M >>> 2) ^ (O << 25 | M >>> 7)
												,
												ve = (P >>> 14 | N << 18) ^ (P >>> 18 | N << 14) ^ (P << 23 | N >>> 9)
												,
												me = (N >>> 14 | P << 18) ^ (N >>> 18 | P << 14) ^ (N << 23 | P >>> 9)
												, ye = l[z]
												, be = ye.high
												, _e = ye.low
												, we = Q + me
												, xe = Y + ve + (we >>> 0 < Q >>> 0 ? 1 : 0)
												, ke = (we = we + fe,
													xe = xe + de + (we >>> 0 < fe >>> 0 ? 1 : 0),
													we = we + _e,
													xe = xe + be + (we >>> 0 < _e >>> 0 ? 1 : 0),
													we = we + q,
													xe = xe + $ + (we >>> 0 < q >>> 0 ? 1 : 0),
												ge + Ae)
												, Se = pe + he + (ke >>> 0 < ge >>> 0 ? 1 : 0);
											Y = R,
												Q = V,
												R = U,
												V = H,
												U = P,
												H = N,
												N = I + we | 0,
												P = F + xe + (N >>> 0 < I >>> 0 ? 1 : 0) | 0,
												F = j,
												I = D,
												j = E,
												D = T,
												E = M,
												T = O,
												O = we + ke | 0,
												M = xe + Se + (O >>> 0 < we >>> 0 ? 1 : 0) | 0
										}
										A = i.low = A + O,
											i.high = h + M + (A >>> 0 < O >>> 0 ? 1 : 0),
											g = r.low = g + T,
											r.high = p + E + (g >>> 0 < T >>> 0 ? 1 : 0),
											m = a.low = m + D,
											a.high = v + j + (m >>> 0 < D >>> 0 ? 1 : 0),
											b = o.low = b + I,
											o.high = y + F + (b >>> 0 < I >>> 0 ? 1 : 0),
											w = s.low = w + N,
											s.high = _ + P + (w >>> 0 < N >>> 0 ? 1 : 0),
											k = c.low = k + H,
											c.high = x + U + (k >>> 0 < H >>> 0 ? 1 : 0),
											C = d.low = C + V,
											d.high = S + R + (C >>> 0 < V >>> 0 ? 1 : 0),
											L = f.low = L + Q,
											f.high = B + Y + (L >>> 0 < Q >>> 0 ? 1 : 0)
									},
									_doFinalize: function () {
										var e = this._data
											, t = e.words
											, n = 8 * this._nDataBytes
											, i = 8 * e.sigBytes;
										t[i >>> 5] |= 128 << 24 - i % 32,
											t[30 + (i + 128 >>> 10 << 5)] = Math.floor(n / 4294967296),
											t[31 + (i + 128 >>> 10 << 5)] = n,
											e.sigBytes = 4 * t.length,
											this._process();
										var r = this._hash.toX32();
										return r
									},
									clone: function () {
										var e = i.clone.call(this);
										return e._hash = this._hash.clone(),
											e
									},
									blockSize: 32
								});
								t.SHA512 = i._createHelper(d),
									t.HmacSHA512 = i._createHmacHelper(d)
							}(),
							function () {
								var t = e
									, n = t.x64
									, i = n.Word
									, r = n.WordArray
									, a = t.algo
									, o = a.SHA512
									, s = a.SHA384 = o.extend({
									_doReset: function () {
										this._hash = new r.init([new i.init(3418070365, 3238371032), new i.init(1654270250, 914150663), new i.init(2438529370, 812702999), new i.init(355462360, 4144912697), new i.init(1731405415, 4290775857), new i.init(2394180231, 1750603025), new i.init(3675008525, 1694076839), new i.init(1203062813, 3204075428)])
									},
									_doFinalize: function () {
										var e = o._doFinalize.call(this);
										return e.sigBytes -= 16,
											e
									}
								});
								t.SHA384 = o._createHelper(s),
									t.HmacSHA384 = o._createHmacHelper(s)
							}(),
							function (t) {
								var n = e
									, i = n.lib
									, r = i.WordArray
									, a = i.Hasher
									, o = n.x64
									, s = o.Word
									, c = n.algo
									, l = []
									, u = []
									, d = [];
								(function () {
										for (var e = 1, t = 0, n = 0; n < 24; n++) {
											l[e + 5 * t] = (n + 1) * (n + 2) / 2 % 64;
											var i = t % 5
												, r = (2 * e + 3 * t) % 5;
											e = i,
												t = r
										}
										for (e = 0; e < 5; e++)
											for (t = 0; t < 5; t++)
												u[e + 5 * t] = t + (2 * e + 3 * t) % 5 * 5;
										for (var a = 1, o = 0; o < 24; o++) {
											for (var c = 0, f = 0, h = 0; h < 7; h++) {
												if (1 & a) {
													var A = (1 << h) - 1;
													A < 32 ? f ^= 1 << A : c ^= 1 << A - 32
												}
												128 & a ? a = a << 1 ^ 113 : a <<= 1
											}
											d[o] = s.create(c, f)
										}
									}
								)();
								var f = [];
								(function () {
										for (var e = 0; e < 25; e++)
											f[e] = s.create()
									}
								)();
								var h = c.SHA3 = a.extend({
									cfg: a.cfg.extend({
										outputLength: 512
									}),
									_doReset: function () {
										for (var e = this._state = [], t = 0; t < 25; t++)
											e[t] = new s.init;
										this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32
									},
									_doProcessBlock: function (e, t) {
										for (var n = this._state, i = this.blockSize / 2, r = 0; r < i; r++) {
											var a = e[t + 2 * r]
												, o = e[t + 2 * r + 1];
											a = 16711935 & (a << 8 | a >>> 24) | 4278255360 & (a << 24 | a >>> 8),
												o = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8);
											var s = n[r];
											s.high ^= o,
												s.low ^= a
										}
										for (var c = 0; c < 24; c++) {
											for (var h = 0; h < 5; h++) {
												for (var A = 0, p = 0, g = 0; g < 5; g++) {
													s = n[h + 5 * g];
													A ^= s.high,
														p ^= s.low
												}
												var v = f[h];
												v.high = A,
													v.low = p
											}
											for (h = 0; h < 5; h++) {
												var m = f[(h + 4) % 5]
													, y = f[(h + 1) % 5]
													, b = y.high
													, _ = y.low;
												for (A = m.high ^ (b << 1 | _ >>> 31),
														 p = m.low ^ (_ << 1 | b >>> 31),
														 g = 0; g < 5; g++) {
													s = n[h + 5 * g];
													s.high ^= A,
														s.low ^= p
												}
											}
											for (var w = 1; w < 25; w++) {
												s = n[w];
												var x = s.high
													, k = s.low
													, S = l[w];
												S < 32 ? (A = x << S | k >>> 32 - S,
													p = k << S | x >>> 32 - S) : (A = k << S - 32 | x >>> 64 - S,
													p = x << S - 32 | k >>> 64 - S);
												var C = f[u[w]];
												C.high = A,
													C.low = p
											}
											var B = f[0]
												, L = n[0];
											B.high = L.high,
												B.low = L.low;
											for (h = 0; h < 5; h++)
												for (g = 0; g < 5; g++) {
													w = h + 5 * g,
														s = n[w];
													var M = f[w]
														, O = f[(h + 1) % 5 + 5 * g]
														, E = f[(h + 2) % 5 + 5 * g];
													s.high = M.high ^ ~O.high & E.high,
														s.low = M.low ^ ~O.low & E.low
												}
											s = n[0];
											var T = d[c];
											s.high ^= T.high,
												s.low ^= T.low
										}
									},
									_doFinalize: function () {
										var e = this._data
											, n = e.words
											, i = (this._nDataBytes,
										8 * e.sigBytes)
											, a = 32 * this.blockSize;
										n[i >>> 5] |= 1 << 24 - i % 32,
											n[(t.ceil((i + 1) / a) * a >>> 5) - 1] |= 128,
											e.sigBytes = 4 * n.length,
											this._process();
										for (var o = this._state, s = this.cfg.outputLength / 8, c = s / 8, l = [], u = 0; u < c; u++) {
											var d = o[u]
												, f = d.high
												, h = d.low;
											f = 16711935 & (f << 8 | f >>> 24) | 4278255360 & (f << 24 | f >>> 8),
												h = 16711935 & (h << 8 | h >>> 24) | 4278255360 & (h << 24 | h >>> 8),
												l.push(h),
												l.push(f)
										}
										return new r.init(l, s)
									},
									clone: function () {
										for (var e = a.clone.call(this), t = e._state = this._state.slice(0), n = 0; n < 25; n++)
											t[n] = t[n].clone();
										return e
									}
								});
								n.SHA3 = a._createHelper(h),
									n.HmacSHA3 = a._createHmacHelper(h)
							}(Math),
							/** @preserve
							 (c) 2012 by Cédric Mesnil. All rights reserved.
							 Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
							 - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
							 - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
							 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
							 */
							function (t) {
								var n = e
									, i = n.lib
									, r = i.WordArray
									, a = i.Hasher
									, o = n.algo
									,
									s = r.create([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13])
									,
									c = r.create([5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11])
									,
									l = r.create([11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6])
									,
									u = r.create([8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11])
									, d = r.create([0, 1518500249, 1859775393, 2400959708, 2840853838])
									, f = r.create([1352829926, 1548603684, 1836072691, 2053994217, 0])
									, h = o.RIPEMD160 = a.extend({
										_doReset: function () {
											this._hash = r.create([1732584193, 4023233417, 2562383102, 271733878, 3285377520])
										},
										_doProcessBlock: function (e, t) {
											for (var n = 0; n < 16; n++) {
												var i = t + n
													, r = e[i];
												e[i] = 16711935 & (r << 8 | r >>> 24) | 4278255360 & (r << 24 | r >>> 8)
											}
											var a, o, h, b, _, w, x, k, S, C, B, L = this._hash.words, M = d.words,
												O = f.words, E = s.words, T = c.words, j = l.words, D = u.words;
											w = a = L[0],
												x = o = L[1],
												k = h = L[2],
												S = b = L[3],
												C = _ = L[4];
											for (n = 0; n < 80; n += 1)
												B = a + e[t + E[n]] | 0,
													B += n < 16 ? A(o, h, b) + M[0] : n < 32 ? p(o, h, b) + M[1] : n < 48 ? g(o, h, b) + M[2] : n < 64 ? v(o, h, b) + M[3] : m(o, h, b) + M[4],
													B |= 0,
													B = y(B, j[n]),
													B = B + _ | 0,
													a = _,
													_ = b,
													b = y(h, 10),
													h = o,
													o = B,
													B = w + e[t + T[n]] | 0,
													B += n < 16 ? m(x, k, S) + O[0] : n < 32 ? v(x, k, S) + O[1] : n < 48 ? g(x, k, S) + O[2] : n < 64 ? p(x, k, S) + O[3] : A(x, k, S) + O[4],
													B |= 0,
													B = y(B, D[n]),
													B = B + C | 0,
													w = C,
													C = S,
													S = y(k, 10),
													k = x,
													x = B;
											B = L[1] + h + S | 0,
												L[1] = L[2] + b + C | 0,
												L[2] = L[3] + _ + w | 0,
												L[3] = L[4] + a + x | 0,
												L[4] = L[0] + o + k | 0,
												L[0] = B
										},
										_doFinalize: function () {
											var e = this._data
												, t = e.words
												, n = 8 * this._nDataBytes
												, i = 8 * e.sigBytes;
											t[i >>> 5] |= 128 << 24 - i % 32,
												t[14 + (i + 64 >>> 9 << 4)] = 16711935 & (n << 8 | n >>> 24) | 4278255360 & (n << 24 | n >>> 8),
												e.sigBytes = 4 * (t.length + 1),
												this._process();
											for (var r = this._hash, a = r.words, o = 0; o < 5; o++) {
												var s = a[o];
												a[o] = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8)
											}
											return r
										},
										clone: function () {
											var e = a.clone.call(this);
											return e._hash = this._hash.clone(),
												e
										}
									});

								function A(e, t, n) {
									return e ^ t ^ n
								}

								function p(e, t, n) {
									return e & t | ~e & n
								}

								function g(e, t, n) {
									return (e | ~t) ^ n
								}

								function v(e, t, n) {
									return e & n | t & ~n
								}

								function m(e, t, n) {
									return e ^ (t | ~n)
								}

								function y(e, t) {
									return e << t | e >>> 32 - t
								}

								n.RIPEMD160 = a._createHelper(h),
									n.HmacRIPEMD160 = a._createHmacHelper(h)
							}(Math),
							function () {
								var t = e
									, n = t.lib
									, i = n.Base
									, r = t.enc
									, a = r.Utf8
									, o = t.algo;
								o.HMAC = i.extend({
									init: function (e, t) {
										e = this._hasher = new e.init,
										"string" == typeof t && (t = a.parse(t));
										var n = e.blockSize
											, i = 4 * n;
										t.sigBytes > i && (t = e.finalize(t)),
											t.clamp();
										for (var r = this._oKey = t.clone(), o = this._iKey = t.clone(), s = r.words, c = o.words, l = 0; l < n; l++)
											s[l] ^= 1549556828,
												c[l] ^= 909522486;
										r.sigBytes = o.sigBytes = i,
											this.reset()
									},
									reset: function () {
										var e = this._hasher;
										e.reset(),
											e.update(this._iKey)
									},
									update: function (e) {
										return this._hasher.update(e),
											this
									},
									finalize: function (e) {
										var t = this._hasher
											, n = t.finalize(e);
										t.reset();
										var i = t.finalize(this._oKey.clone().concat(n));
										return i
									}
								})
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.Base
									, r = n.WordArray
									, a = t.algo
									, o = a.SHA1
									, s = a.HMAC
									, c = a.PBKDF2 = i.extend({
									cfg: i.extend({
										keySize: 4,
										hasher: o,
										iterations: 1
									}),
									init: function (e) {
										this.cfg = this.cfg.extend(e)
									},
									compute: function (e, t) {
										var n = this.cfg
											, i = s.create(n.hasher, e)
											, a = r.create()
											, o = r.create([1])
											, c = a.words
											, l = o.words
											, u = n.keySize
											, d = n.iterations;
										while (c.length < u) {
											var f = i.update(t).finalize(o);
											i.reset();
											for (var h = f.words, A = h.length, p = f, g = 1; g < d; g++) {
												p = i.finalize(p),
													i.reset();
												for (var v = p.words, m = 0; m < A; m++)
													h[m] ^= v[m]
											}
											a.concat(f),
												l[0]++
										}
										return a.sigBytes = 4 * u,
											a
									}
								});
								t.PBKDF2 = function (e, t, n) {
									return c.create(n).compute(e, t)
								}
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.Base
									, r = n.WordArray
									, a = t.algo
									, o = a.MD5
									, s = a.EvpKDF = i.extend({
									cfg: i.extend({
										keySize: 4,
										hasher: o,
										iterations: 1
									}),
									init: function (e) {
										this.cfg = this.cfg.extend(e)
									},
									compute: function (e, t) {
										var n, i = this.cfg, a = i.hasher.create(), o = r.create(), s = o.words,
											c = i.keySize, l = i.iterations;
										while (s.length < c) {
											n && a.update(n),
												n = a.update(e).finalize(t),
												a.reset();
											for (var u = 1; u < l; u++)
												n = a.finalize(n),
													a.reset();
											o.concat(n)
										}
										return o.sigBytes = 4 * c,
											o
									}
								});
								t.EvpKDF = function (e, t, n) {
									return s.create(n).compute(e, t)
								}
							}(),
						e.lib.Cipher || function (t) {
							var n = e
								, i = n.lib
								, r = i.Base
								, a = i.WordArray
								, o = i.BufferedBlockAlgorithm
								, s = n.enc
								, c = (s.Utf8,
								s.Base64)
								, l = n.algo
								, u = l.EvpKDF
								, d = i.Cipher = o.extend({
								cfg: r.extend(),
								createEncryptor: function (e, t) {
									return this.create(this._ENC_XFORM_MODE, e, t)
								},
								createDecryptor: function (e, t) {
									return this.create(this._DEC_XFORM_MODE, e, t)
								},
								init: function (e, t, n) {
									this.cfg = this.cfg.extend(n),
										this._xformMode = e,
										this._key = t,
										this.reset()
								},
								reset: function () {
									o.reset.call(this),
										this._doReset()
								},
								process: function (e) {
									return this._append(e),
										this._process()
								},
								finalize: function (e) {
									e && this._append(e);
									var t = this._doFinalize();
									return t
								},
								keySize: 4,
								ivSize: 4,
								_ENC_XFORM_MODE: 1,
								_DEC_XFORM_MODE: 2,
								_createHelper: function () {
									function e(e) {
										return "string" == typeof e ? x : b
									}

									return function (t) {
										return {
											encrypt: function (n, i, r) {
												return e(i).encrypt(t, n, i, r)
											},
											decrypt: function (n, i, r) {
												return e(i).decrypt(t, n, i, r)
											}
										}
									}
								}()
							})
								, f = (i.StreamCipher = d.extend({
								_doFinalize: function () {
									var e = this._process(!0);
									return e
								},
								blockSize: 1
							}),
								n.mode = {})
								, h = i.BlockCipherMode = r.extend({
								createEncryptor: function (e, t) {
									return this.Encryptor.create(e, t)
								},
								createDecryptor: function (e, t) {
									return this.Decryptor.create(e, t)
								},
								init: function (e, t) {
									this._cipher = e,
										this._iv = t
								}
							})
								, A = f.CBC = function () {
								var e = h.extend();

								function n(e, n, i) {
									var r, a = this._iv;
									a ? (r = a,
										this._iv = t) : r = this._prevBlock;
									for (var o = 0; o < i; o++)
										e[n + o] ^= r[o]
								}

								return e.Encryptor = e.extend({
									processBlock: function (e, t) {
										var i = this._cipher
											, r = i.blockSize;
										n.call(this, e, t, r),
											i.encryptBlock(e, t),
											this._prevBlock = e.slice(t, t + r)
									}
								}),
									e.Decryptor = e.extend({
										processBlock: function (e, t) {
											var i = this._cipher
												, r = i.blockSize
												, a = e.slice(t, t + r);
											i.decryptBlock(e, t),
												n.call(this, e, t, r),
												this._prevBlock = a
										}
									}),
									e
							}()
								, p = n.pad = {}
								, g = p.Pkcs7 = {
								pad: function (e, t) {
									for (var n = 4 * t, i = n - e.sigBytes % n, r = i << 24 | i << 16 | i << 8 | i, o = [], s = 0; s < i; s += 4)
										o.push(r);
									var c = a.create(o, i);
									e.concat(c)
								},
								unpad: function (e) {
									var t = 255 & e.words[e.sigBytes - 1 >>> 2];
									e.sigBytes -= t
								}
							}
								, v = (i.BlockCipher = d.extend({
								cfg: d.cfg.extend({
									mode: A,
									padding: g
								}),
								reset: function () {
									var e;
									d.reset.call(this);
									var t = this.cfg
										, n = t.iv
										, i = t.mode;
									this._xformMode == this._ENC_XFORM_MODE ? e = i.createEncryptor : (e = i.createDecryptor,
										this._minBufferSize = 1),
										this._mode && this._mode.__creator == e ? this._mode.init(this, n && n.words) : (this._mode = e.call(i, this, n && n.words),
											this._mode.__creator = e)
								},
								_doProcessBlock: function (e, t) {
									this._mode.processBlock(e, t)
								},
								_doFinalize: function () {
									var e, t = this.cfg.padding;
									return this._xformMode == this._ENC_XFORM_MODE ? (t.pad(this._data, this.blockSize),
										e = this._process(!0)) : (e = this._process(!0),
										t.unpad(e)),
										e
								},
								blockSize: 4
							}),
								i.CipherParams = r.extend({
									init: function (e) {
										this.mixIn(e)
									},
									toString: function (e) {
										return (e || this.formatter).stringify(this)
									}
								}))
								, m = n.format = {}
								, y = m.OpenSSL = {
								stringify: function (e) {
									var t, n = e.ciphertext, i = e.salt;
									return t = i ? a.create([1398893684, 1701076831]).concat(i).concat(n) : n,
										t.toString(c)
								},
								parse: function (e) {
									var t, n = c.parse(e), i = n.words;
									return 1398893684 == i[0] && 1701076831 == i[1] && (t = a.create(i.slice(2, 4)),
										i.splice(0, 4),
										n.sigBytes -= 16),
										v.create({
											ciphertext: n,
											salt: t
										})
								}
							}
								, b = i.SerializableCipher = r.extend({
								cfg: r.extend({
									format: y
								}),
								encrypt: function (e, t, n, i) {
									i = this.cfg.extend(i);
									var r = e.createEncryptor(n, i)
										, a = r.finalize(t)
										, o = r.cfg;
									return v.create({
										ciphertext: a,
										key: n,
										iv: o.iv,
										algorithm: e,
										mode: o.mode,
										padding: o.padding,
										blockSize: e.blockSize,
										formatter: i.format
									})
								},
								decrypt: function (e, t, n, i) {
									i = this.cfg.extend(i),
										t = this._parse(t, i.format);
									var r = e.createDecryptor(n, i).finalize(t.ciphertext);
									return r
								},
								_parse: function (e, t) {
									return "string" == typeof e ? t.parse(e, this) : e
								}
							})
								, _ = n.kdf = {}
								, w = _.OpenSSL = {
								execute: function (e, t, n, i) {
									i || (i = a.random(8));
									var r = u.create({
										keySize: t + n
									}).compute(e, i)
										, o = a.create(r.words.slice(t), 4 * n);
									return r.sigBytes = 4 * t,
										v.create({
											key: r,
											iv: o,
											salt: i
										})
								}
							}
								, x = i.PasswordBasedCipher = b.extend({
								cfg: b.cfg.extend({
									kdf: w
								}),
								encrypt: function (e, t, n, i) {
									i = this.cfg.extend(i);
									var r = i.kdf.execute(n, e.keySize, e.ivSize);
									i.iv = r.iv;
									var a = b.encrypt.call(this, e, t, r.key, i);
									return a.mixIn(r),
										a
								},
								decrypt: function (e, t, n, i) {
									i = this.cfg.extend(i),
										t = this._parse(t, i.format);
									var r = i.kdf.execute(n, e.keySize, e.ivSize, t.salt);
									i.iv = r.iv;
									var a = b.decrypt.call(this, e, t, r.key, i);
									return a
								}
							})
						}(),
							e.mode.CFB = function () {
								var t = e.lib.BlockCipherMode.extend();

								function n(e, t, n, i) {
									var r, a = this._iv;
									a ? (r = a.slice(0),
										this._iv = void 0) : r = this._prevBlock,
										i.encryptBlock(r, 0);
									for (var o = 0; o < n; o++)
										e[t + o] ^= r[o]
								}

								return t.Encryptor = t.extend({
									processBlock: function (e, t) {
										var i = this._cipher
											, r = i.blockSize;
										n.call(this, e, t, r, i),
											this._prevBlock = e.slice(t, t + r)
									}
								}),
									t.Decryptor = t.extend({
										processBlock: function (e, t) {
											var i = this._cipher
												, r = i.blockSize
												, a = e.slice(t, t + r);
											n.call(this, e, t, r, i),
												this._prevBlock = a
										}
									}),
									t
							}(),
							e.mode.CTR = function () {
								var t = e.lib.BlockCipherMode.extend()
									, n = t.Encryptor = t.extend({
									processBlock: function (e, t) {
										var n = this._cipher
											, i = n.blockSize
											, r = this._iv
											, a = this._counter;
										r && (a = this._counter = r.slice(0),
											this._iv = void 0);
										var o = a.slice(0);
										n.encryptBlock(o, 0),
											a[i - 1] = a[i - 1] + 1 | 0;
										for (var s = 0; s < i; s++)
											e[t + s] ^= o[s]
									}
								});
								return t.Decryptor = n,
									t
							}(),
							/** @preserve
							 * Counter block mode compatible with  Dr Brian Gladman fileenc.c
							 * derived from CryptoJS.mode.CTR
							 * Jan Hruby jhruby.web@gmail.com
							 */
							e.mode.CTRGladman = function () {
								var t = e.lib.BlockCipherMode.extend();

								function n(e) {
									if (255 === (e >> 24 & 255)) {
										var t = e >> 16 & 255
											, n = e >> 8 & 255
											, i = 255 & e;
										255 === t ? (t = 0,
											255 === n ? (n = 0,
												255 === i ? i = 0 : ++i) : ++n) : ++t,
											e = 0,
											e += t << 16,
											e += n << 8,
											e += i
									} else
										e += 1 << 24;
									return e
								}

								function i(e) {
									return 0 === (e[0] = n(e[0])) && (e[1] = n(e[1])),
										e
								}

								var r = t.Encryptor = t.extend({
									processBlock: function (e, t) {
										var n = this._cipher
											, r = n.blockSize
											, a = this._iv
											, o = this._counter;
										a && (o = this._counter = a.slice(0),
											this._iv = void 0),
											i(o);
										var s = o.slice(0);
										n.encryptBlock(s, 0);
										for (var c = 0; c < r; c++)
											e[t + c] ^= s[c]
									}
								});
								return t.Decryptor = r,
									t
							}(),
							e.mode.OFB = function () {
								var t = e.lib.BlockCipherMode.extend()
									, n = t.Encryptor = t.extend({
									processBlock: function (e, t) {
										var n = this._cipher
											, i = n.blockSize
											, r = this._iv
											, a = this._keystream;
										r && (a = this._keystream = r.slice(0),
											this._iv = void 0),
											n.encryptBlock(a, 0);
										for (var o = 0; o < i; o++)
											e[t + o] ^= a[o]
									}
								});
								return t.Decryptor = n,
									t
							}(),
							e.mode.ECB = function () {
								var t = e.lib.BlockCipherMode.extend();
								return t.Encryptor = t.extend({
									processBlock: function (e, t) {
										this._cipher.encryptBlock(e, t)
									}
								}),
									t.Decryptor = t.extend({
										processBlock: function (e, t) {
											this._cipher.decryptBlock(e, t)
										}
									}),
									t
							}(),
							e.pad.AnsiX923 = {
								pad: function (e, t) {
									var n = e.sigBytes
										, i = 4 * t
										, r = i - n % i
										, a = n + r - 1;
									e.clamp(),
										e.words[a >>> 2] |= r << 24 - a % 4 * 8,
										e.sigBytes += r
								},
								unpad: function (e) {
									var t = 255 & e.words[e.sigBytes - 1 >>> 2];
									e.sigBytes -= t
								}
							},
							e.pad.Iso10126 = {
								pad: function (t, n) {
									var i = 4 * n
										, r = i - t.sigBytes % i;
									t.concat(e.lib.WordArray.random(r - 1)).concat(e.lib.WordArray.create([r << 24], 1))
								},
								unpad: function (e) {
									var t = 255 & e.words[e.sigBytes - 1 >>> 2];
									e.sigBytes -= t
								}
							},
							e.pad.Iso97971 = {
								pad: function (t, n) {
									t.concat(e.lib.WordArray.create([2147483648], 1)),
										e.pad.ZeroPadding.pad(t, n)
								},
								unpad: function (t) {
									e.pad.ZeroPadding.unpad(t),
										t.sigBytes--
								}
							},
							e.pad.ZeroPadding = {
								pad: function (e, t) {
									var n = 4 * t;
									e.clamp(),
										e.sigBytes += n - (e.sigBytes % n || n)
								},
								unpad: function (e) {
									var t = e.words
										, n = e.sigBytes - 1;
									for (n = e.sigBytes - 1; n >= 0; n--)
										if (t[n >>> 2] >>> 24 - n % 4 * 8 & 255) {
											e.sigBytes = n + 1;
											break
										}
								}
							},
							e.pad.NoPadding = {
								pad: function () {
								},
								unpad: function () {
								}
							},
							function (t) {
								var n = e
									, i = n.lib
									, r = i.CipherParams
									, a = n.enc
									, o = a.Hex
									, s = n.format;
								s.Hex = {
									stringify: function (e) {
										return e.ciphertext.toString(o)
									},
									parse: function (e) {
										var t = o.parse(e);
										return r.create({
											ciphertext: t
										})
									}
								}
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.BlockCipher
									, r = t.algo
									, a = []
									, o = []
									, s = []
									, c = []
									, l = []
									, u = []
									, d = []
									, f = []
									, h = []
									, A = [];
								(function () {
										for (var e = [], t = 0; t < 256; t++)
											e[t] = t < 128 ? t << 1 : t << 1 ^ 283;
										var n = 0
											, i = 0;
										for (t = 0; t < 256; t++) {
											var r = i ^ i << 1 ^ i << 2 ^ i << 3 ^ i << 4;
											r = r >>> 8 ^ 255 & r ^ 99,
												a[n] = r,
												o[r] = n;
											var p = e[n]
												, g = e[p]
												, v = e[g]
												, m = 257 * e[r] ^ 16843008 * r;
											s[n] = m << 24 | m >>> 8,
												c[n] = m << 16 | m >>> 16,
												l[n] = m << 8 | m >>> 24,
												u[n] = m;
											m = 16843009 * v ^ 65537 * g ^ 257 * p ^ 16843008 * n;
											d[r] = m << 24 | m >>> 8,
												f[r] = m << 16 | m >>> 16,
												h[r] = m << 8 | m >>> 24,
												A[r] = m,
												n ? (n = p ^ e[e[e[v ^ p]]],
													i ^= e[e[i]]) : n = i = 1
										}
									}
								)();
								var p = [0, 1, 2, 4, 8, 16, 32, 64, 128, 27, 54]
									, g = r.AES = i.extend({
									_doReset: function () {
										if (!this._nRounds || this._keyPriorReset !== this._key) {
											for (var e = this._keyPriorReset = this._key, t = e.words, n = e.sigBytes / 4, i = this._nRounds = n + 6, r = 4 * (i + 1), o = this._keySchedule = [], s = 0; s < r; s++)
												s < n ? o[s] = t[s] : (u = o[s - 1],
													s % n ? n > 6 && s % n == 4 && (u = a[u >>> 24] << 24 | a[u >>> 16 & 255] << 16 | a[u >>> 8 & 255] << 8 | a[255 & u]) : (u = u << 8 | u >>> 24,
														u = a[u >>> 24] << 24 | a[u >>> 16 & 255] << 16 | a[u >>> 8 & 255] << 8 | a[255 & u],
														u ^= p[s / n | 0] << 24),
													o[s] = o[s - n] ^ u);
											for (var c = this._invKeySchedule = [], l = 0; l < r; l++) {
												s = r - l;
												if (l % 4)
													var u = o[s];
												else
													u = o[s - 4];
												c[l] = l < 4 || s <= 4 ? u : d[a[u >>> 24]] ^ f[a[u >>> 16 & 255]] ^ h[a[u >>> 8 & 255]] ^ A[a[255 & u]]
											}
										}
									},
									encryptBlock: function (e, t) {
										this._doCryptBlock(e, t, this._keySchedule, s, c, l, u, a)
									},
									decryptBlock: function (e, t) {
										var n = e[t + 1];
										e[t + 1] = e[t + 3],
											e[t + 3] = n,
											this._doCryptBlock(e, t, this._invKeySchedule, d, f, h, A, o);
										n = e[t + 1];
										e[t + 1] = e[t + 3],
											e[t + 3] = n
									},
									_doCryptBlock: function (e, t, n, i, r, a, o, s) {
										for (var c = this._nRounds, l = e[t] ^ n[0], u = e[t + 1] ^ n[1], d = e[t + 2] ^ n[2], f = e[t + 3] ^ n[3], h = 4, A = 1; A < c; A++) {
											var p = i[l >>> 24] ^ r[u >>> 16 & 255] ^ a[d >>> 8 & 255] ^ o[255 & f] ^ n[h++]
												,
												g = i[u >>> 24] ^ r[d >>> 16 & 255] ^ a[f >>> 8 & 255] ^ o[255 & l] ^ n[h++]
												,
												v = i[d >>> 24] ^ r[f >>> 16 & 255] ^ a[l >>> 8 & 255] ^ o[255 & u] ^ n[h++]
												,
												m = i[f >>> 24] ^ r[l >>> 16 & 255] ^ a[u >>> 8 & 255] ^ o[255 & d] ^ n[h++];
											l = p,
												u = g,
												d = v,
												f = m
										}
										p = (s[l >>> 24] << 24 | s[u >>> 16 & 255] << 16 | s[d >>> 8 & 255] << 8 | s[255 & f]) ^ n[h++],
											g = (s[u >>> 24] << 24 | s[d >>> 16 & 255] << 16 | s[f >>> 8 & 255] << 8 | s[255 & l]) ^ n[h++],
											v = (s[d >>> 24] << 24 | s[f >>> 16 & 255] << 16 | s[l >>> 8 & 255] << 8 | s[255 & u]) ^ n[h++],
											m = (s[f >>> 24] << 24 | s[l >>> 16 & 255] << 16 | s[u >>> 8 & 255] << 8 | s[255 & d]) ^ n[h++];
										e[t] = p,
											e[t + 1] = g,
											e[t + 2] = v,
											e[t + 3] = m
									},
									keySize: 8
								});
								t.AES = i._createHelper(g)
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.WordArray
									, r = n.BlockCipher
									, a = t.algo
									,
									o = [57, 49, 41, 33, 25, 17, 9, 1, 58, 50, 42, 34, 26, 18, 10, 2, 59, 51, 43, 35, 27, 19, 11, 3, 60, 52, 44, 36, 63, 55, 47, 39, 31, 23, 15, 7, 62, 54, 46, 38, 30, 22, 14, 6, 61, 53, 45, 37, 29, 21, 13, 5, 28, 20, 12, 4]
									,
									s = [14, 17, 11, 24, 1, 5, 3, 28, 15, 6, 21, 10, 23, 19, 12, 4, 26, 8, 16, 7, 27, 20, 13, 2, 41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48, 44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32]
									, c = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28]
									, l = [{
										0: 8421888,
										268435456: 32768,
										536870912: 8421378,
										805306368: 2,
										1073741824: 512,
										1342177280: 8421890,
										1610612736: 8389122,
										1879048192: 8388608,
										2147483648: 514,
										2415919104: 8389120,
										2684354560: 33280,
										2952790016: 8421376,
										3221225472: 32770,
										3489660928: 8388610,
										3758096384: 0,
										4026531840: 33282,
										134217728: 0,
										402653184: 8421890,
										671088640: 33282,
										939524096: 32768,
										1207959552: 8421888,
										1476395008: 512,
										1744830464: 8421378,
										2013265920: 2,
										2281701376: 8389120,
										2550136832: 33280,
										2818572288: 8421376,
										3087007744: 8389122,
										3355443200: 8388610,
										3623878656: 32770,
										3892314112: 514,
										4160749568: 8388608,
										1: 32768,
										268435457: 2,
										536870913: 8421888,
										805306369: 8388608,
										1073741825: 8421378,
										1342177281: 33280,
										1610612737: 512,
										1879048193: 8389122,
										2147483649: 8421890,
										2415919105: 8421376,
										2684354561: 8388610,
										2952790017: 33282,
										3221225473: 514,
										3489660929: 8389120,
										3758096385: 32770,
										4026531841: 0,
										134217729: 8421890,
										402653185: 8421376,
										671088641: 8388608,
										939524097: 512,
										1207959553: 32768,
										1476395009: 8388610,
										1744830465: 2,
										2013265921: 33282,
										2281701377: 32770,
										2550136833: 8389122,
										2818572289: 514,
										3087007745: 8421888,
										3355443201: 8389120,
										3623878657: 0,
										3892314113: 33280,
										4160749569: 8421378
									}, {
										0: 1074282512,
										16777216: 16384,
										33554432: 524288,
										50331648: 1074266128,
										67108864: 1073741840,
										83886080: 1074282496,
										100663296: 1073758208,
										117440512: 16,
										134217728: 540672,
										150994944: 1073758224,
										167772160: 1073741824,
										184549376: 540688,
										201326592: 524304,
										218103808: 0,
										234881024: 16400,
										251658240: 1074266112,
										8388608: 1073758208,
										25165824: 540688,
										41943040: 16,
										58720256: 1073758224,
										75497472: 1074282512,
										92274688: 1073741824,
										109051904: 524288,
										125829120: 1074266128,
										142606336: 524304,
										159383552: 0,
										176160768: 16384,
										192937984: 1074266112,
										209715200: 1073741840,
										226492416: 540672,
										243269632: 1074282496,
										260046848: 16400,
										268435456: 0,
										285212672: 1074266128,
										301989888: 1073758224,
										318767104: 1074282496,
										335544320: 1074266112,
										352321536: 16,
										369098752: 540688,
										385875968: 16384,
										402653184: 16400,
										419430400: 524288,
										436207616: 524304,
										452984832: 1073741840,
										469762048: 540672,
										486539264: 1073758208,
										503316480: 1073741824,
										520093696: 1074282512,
										276824064: 540688,
										293601280: 524288,
										310378496: 1074266112,
										327155712: 16384,
										343932928: 1073758208,
										360710144: 1074282512,
										377487360: 16,
										394264576: 1073741824,
										411041792: 1074282496,
										427819008: 1073741840,
										444596224: 1073758224,
										461373440: 524304,
										478150656: 0,
										494927872: 16400,
										511705088: 1074266128,
										528482304: 540672
									}, {
										0: 260,
										1048576: 0,
										2097152: 67109120,
										3145728: 65796,
										4194304: 65540,
										5242880: 67108868,
										6291456: 67174660,
										7340032: 67174400,
										8388608: 67108864,
										9437184: 67174656,
										10485760: 65792,
										11534336: 67174404,
										12582912: 67109124,
										13631488: 65536,
										14680064: 4,
										15728640: 256,
										524288: 67174656,
										1572864: 67174404,
										2621440: 0,
										3670016: 67109120,
										4718592: 67108868,
										5767168: 65536,
										6815744: 65540,
										7864320: 260,
										8912896: 4,
										9961472: 256,
										11010048: 67174400,
										12058624: 65796,
										13107200: 65792,
										14155776: 67109124,
										15204352: 67174660,
										16252928: 67108864,
										16777216: 67174656,
										17825792: 65540,
										18874368: 65536,
										19922944: 67109120,
										20971520: 256,
										22020096: 67174660,
										23068672: 67108868,
										24117248: 0,
										25165824: 67109124,
										26214400: 67108864,
										27262976: 4,
										28311552: 65792,
										29360128: 67174400,
										30408704: 260,
										31457280: 65796,
										32505856: 67174404,
										17301504: 67108864,
										18350080: 260,
										19398656: 67174656,
										20447232: 0,
										21495808: 65540,
										22544384: 67109120,
										23592960: 256,
										24641536: 67174404,
										25690112: 65536,
										26738688: 67174660,
										27787264: 65796,
										28835840: 67108868,
										29884416: 67109124,
										30932992: 67174400,
										31981568: 4,
										33030144: 65792
									}, {
										0: 2151682048,
										65536: 2147487808,
										131072: 4198464,
										196608: 2151677952,
										262144: 0,
										327680: 4198400,
										393216: 2147483712,
										458752: 4194368,
										524288: 2147483648,
										589824: 4194304,
										655360: 64,
										720896: 2147487744,
										786432: 2151678016,
										851968: 4160,
										917504: 4096,
										983040: 2151682112,
										32768: 2147487808,
										98304: 64,
										163840: 2151678016,
										229376: 2147487744,
										294912: 4198400,
										360448: 2151682112,
										425984: 0,
										491520: 2151677952,
										557056: 4096,
										622592: 2151682048,
										688128: 4194304,
										753664: 4160,
										819200: 2147483648,
										884736: 4194368,
										950272: 4198464,
										1015808: 2147483712,
										1048576: 4194368,
										1114112: 4198400,
										1179648: 2147483712,
										1245184: 0,
										1310720: 4160,
										1376256: 2151678016,
										1441792: 2151682048,
										1507328: 2147487808,
										1572864: 2151682112,
										1638400: 2147483648,
										1703936: 2151677952,
										1769472: 4198464,
										1835008: 2147487744,
										1900544: 4194304,
										1966080: 64,
										2031616: 4096,
										1081344: 2151677952,
										1146880: 2151682112,
										1212416: 0,
										1277952: 4198400,
										1343488: 4194368,
										1409024: 2147483648,
										1474560: 2147487808,
										1540096: 64,
										1605632: 2147483712,
										1671168: 4096,
										1736704: 2147487744,
										1802240: 2151678016,
										1867776: 4160,
										1933312: 2151682048,
										1998848: 4194304,
										2064384: 4198464
									}, {
										0: 128,
										4096: 17039360,
										8192: 262144,
										12288: 536870912,
										16384: 537133184,
										20480: 16777344,
										24576: 553648256,
										28672: 262272,
										32768: 16777216,
										36864: 537133056,
										40960: 536871040,
										45056: 553910400,
										49152: 553910272,
										53248: 0,
										57344: 17039488,
										61440: 553648128,
										2048: 17039488,
										6144: 553648256,
										10240: 128,
										14336: 17039360,
										18432: 262144,
										22528: 537133184,
										26624: 553910272,
										30720: 536870912,
										34816: 537133056,
										38912: 0,
										43008: 553910400,
										47104: 16777344,
										51200: 536871040,
										55296: 553648128,
										59392: 16777216,
										63488: 262272,
										65536: 262144,
										69632: 128,
										73728: 536870912,
										77824: 553648256,
										81920: 16777344,
										86016: 553910272,
										90112: 537133184,
										94208: 16777216,
										98304: 553910400,
										102400: 553648128,
										106496: 17039360,
										110592: 537133056,
										114688: 262272,
										118784: 536871040,
										122880: 0,
										126976: 17039488,
										67584: 553648256,
										71680: 16777216,
										75776: 17039360,
										79872: 537133184,
										83968: 536870912,
										88064: 17039488,
										92160: 128,
										96256: 553910272,
										100352: 262272,
										104448: 553910400,
										108544: 0,
										112640: 553648128,
										116736: 16777344,
										120832: 262144,
										124928: 537133056,
										129024: 536871040
									}, {
										0: 268435464,
										256: 8192,
										512: 270532608,
										768: 270540808,
										1024: 268443648,
										1280: 2097152,
										1536: 2097160,
										1792: 268435456,
										2048: 0,
										2304: 268443656,
										2560: 2105344,
										2816: 8,
										3072: 270532616,
										3328: 2105352,
										3584: 8200,
										3840: 270540800,
										128: 270532608,
										384: 270540808,
										640: 8,
										896: 2097152,
										1152: 2105352,
										1408: 268435464,
										1664: 268443648,
										1920: 8200,
										2176: 2097160,
										2432: 8192,
										2688: 268443656,
										2944: 270532616,
										3200: 0,
										3456: 270540800,
										3712: 2105344,
										3968: 268435456,
										4096: 268443648,
										4352: 270532616,
										4608: 270540808,
										4864: 8200,
										5120: 2097152,
										5376: 268435456,
										5632: 268435464,
										5888: 2105344,
										6144: 2105352,
										6400: 0,
										6656: 8,
										6912: 270532608,
										7168: 8192,
										7424: 268443656,
										7680: 270540800,
										7936: 2097160,
										4224: 8,
										4480: 2105344,
										4736: 2097152,
										4992: 268435464,
										5248: 268443648,
										5504: 8200,
										5760: 270540808,
										6016: 270532608,
										6272: 270540800,
										6528: 270532616,
										6784: 8192,
										7040: 2105352,
										7296: 2097160,
										7552: 0,
										7808: 268435456,
										8064: 268443656
									}, {
										0: 1048576,
										16: 33555457,
										32: 1024,
										48: 1049601,
										64: 34604033,
										80: 0,
										96: 1,
										112: 34603009,
										128: 33555456,
										144: 1048577,
										160: 33554433,
										176: 34604032,
										192: 34603008,
										208: 1025,
										224: 1049600,
										240: 33554432,
										8: 34603009,
										24: 0,
										40: 33555457,
										56: 34604032,
										72: 1048576,
										88: 33554433,
										104: 33554432,
										120: 1025,
										136: 1049601,
										152: 33555456,
										168: 34603008,
										184: 1048577,
										200: 1024,
										216: 34604033,
										232: 1,
										248: 1049600,
										256: 33554432,
										272: 1048576,
										288: 33555457,
										304: 34603009,
										320: 1048577,
										336: 33555456,
										352: 34604032,
										368: 1049601,
										384: 1025,
										400: 34604033,
										416: 1049600,
										432: 1,
										448: 0,
										464: 34603008,
										480: 33554433,
										496: 1024,
										264: 1049600,
										280: 33555457,
										296: 34603009,
										312: 1,
										328: 33554432,
										344: 1048576,
										360: 1025,
										376: 34604032,
										392: 33554433,
										408: 34603008,
										424: 0,
										440: 34604033,
										456: 1049601,
										472: 1024,
										488: 33555456,
										504: 1048577
									}, {
										0: 134219808,
										1: 131072,
										2: 134217728,
										3: 32,
										4: 131104,
										5: 134350880,
										6: 134350848,
										7: 2048,
										8: 134348800,
										9: 134219776,
										10: 133120,
										11: 134348832,
										12: 2080,
										13: 0,
										14: 134217760,
										15: 133152,
										2147483648: 2048,
										2147483649: 134350880,
										2147483650: 134219808,
										2147483651: 134217728,
										2147483652: 134348800,
										2147483653: 133120,
										2147483654: 133152,
										2147483655: 32,
										2147483656: 134217760,
										2147483657: 2080,
										2147483658: 131104,
										2147483659: 134350848,
										2147483660: 0,
										2147483661: 134348832,
										2147483662: 134219776,
										2147483663: 131072,
										16: 133152,
										17: 134350848,
										18: 32,
										19: 2048,
										20: 134219776,
										21: 134217760,
										22: 134348832,
										23: 131072,
										24: 0,
										25: 131104,
										26: 134348800,
										27: 134219808,
										28: 134350880,
										29: 133120,
										30: 2080,
										31: 134217728,
										2147483664: 131072,
										2147483665: 2048,
										2147483666: 134348832,
										2147483667: 133152,
										2147483668: 32,
										2147483669: 134348800,
										2147483670: 134217728,
										2147483671: 134219808,
										2147483672: 134350880,
										2147483673: 134217760,
										2147483674: 134219776,
										2147483675: 0,
										2147483676: 133120,
										2147483677: 2080,
										2147483678: 131104,
										2147483679: 134350848
									}]
									, u = [4160749569, 528482304, 33030144, 2064384, 129024, 8064, 504, 2147483679]
									, d = a.DES = r.extend({
										_doReset: function () {
											for (var e = this._key, t = e.words, n = [], i = 0; i < 56; i++) {
												var r = o[i] - 1;
												n[i] = t[r >>> 5] >>> 31 - r % 32 & 1
											}
											for (var a = this._subKeys = [], l = 0; l < 16; l++) {
												var u = a[l] = []
													, d = c[l];
												for (i = 0; i < 24; i++)
													u[i / 6 | 0] |= n[(s[i] - 1 + d) % 28] << 31 - i % 6,
														u[4 + (i / 6 | 0)] |= n[28 + (s[i + 24] - 1 + d) % 28] << 31 - i % 6;
												u[0] = u[0] << 1 | u[0] >>> 31;
												for (i = 1; i < 7; i++)
													u[i] = u[i] >>> 4 * (i - 1) + 3;
												u[7] = u[7] << 5 | u[7] >>> 27
											}
											var f = this._invSubKeys = [];
											for (i = 0; i < 16; i++)
												f[i] = a[15 - i]
										},
										encryptBlock: function (e, t) {
											this._doCryptBlock(e, t, this._subKeys)
										},
										decryptBlock: function (e, t) {
											this._doCryptBlock(e, t, this._invSubKeys)
										},
										_doCryptBlock: function (e, t, n) {
											this._lBlock = e[t],
												this._rBlock = e[t + 1],
												f.call(this, 4, 252645135),
												f.call(this, 16, 65535),
												h.call(this, 2, 858993459),
												h.call(this, 8, 16711935),
												f.call(this, 1, 1431655765);
											for (var i = 0; i < 16; i++) {
												for (var r = n[i], a = this._lBlock, o = this._rBlock, s = 0, c = 0; c < 8; c++)
													s |= l[c][((o ^ r[c]) & u[c]) >>> 0];
												this._lBlock = o,
													this._rBlock = a ^ s
											}
											var d = this._lBlock;
											this._lBlock = this._rBlock,
												this._rBlock = d,
												f.call(this, 1, 1431655765),
												h.call(this, 8, 16711935),
												h.call(this, 2, 858993459),
												f.call(this, 16, 65535),
												f.call(this, 4, 252645135),
												e[t] = this._lBlock,
												e[t + 1] = this._rBlock
										},
										keySize: 2,
										ivSize: 2,
										blockSize: 2
									});

								function f(e, t) {
									var n = (this._lBlock >>> e ^ this._rBlock) & t;
									this._rBlock ^= n,
										this._lBlock ^= n << e
								}

								function h(e, t) {
									var n = (this._rBlock >>> e ^ this._lBlock) & t;
									this._lBlock ^= n,
										this._rBlock ^= n << e
								}

								t.DES = r._createHelper(d);
								var A = a.TripleDES = r.extend({
									_doReset: function () {
										var e = this._key
											, t = e.words;
										if (2 !== t.length && 4 !== t.length && t.length < 6)
											throw new Error("Invalid key length - 3DES requires the key length to be 64, 128, 192 or >192.");
										var n = t.slice(0, 2)
											, r = t.length < 4 ? t.slice(0, 2) : t.slice(2, 4)
											, a = t.length < 6 ? t.slice(0, 2) : t.slice(4, 6);
										this._des1 = d.createEncryptor(i.create(n)),
											this._des2 = d.createEncryptor(i.create(r)),
											this._des3 = d.createEncryptor(i.create(a))
									},
									encryptBlock: function (e, t) {
										this._des1.encryptBlock(e, t),
											this._des2.decryptBlock(e, t),
											this._des3.encryptBlock(e, t)
									},
									decryptBlock: function (e, t) {
										this._des3.decryptBlock(e, t),
											this._des2.encryptBlock(e, t),
											this._des1.decryptBlock(e, t)
									},
									keySize: 6,
									ivSize: 2,
									blockSize: 2
								});
								t.TripleDES = r._createHelper(A)
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.StreamCipher
									, r = t.algo
									, a = r.RC4 = i.extend({
									_doReset: function () {
										for (var e = this._key, t = e.words, n = e.sigBytes, i = this._S = [], r = 0; r < 256; r++)
											i[r] = r;
										r = 0;
										for (var a = 0; r < 256; r++) {
											var o = r % n
												, s = t[o >>> 2] >>> 24 - o % 4 * 8 & 255;
											a = (a + i[r] + s) % 256;
											var c = i[r];
											i[r] = i[a],
												i[a] = c
										}
										this._i = this._j = 0
									},
									_doProcessBlock: function (e, t) {
										e[t] ^= o.call(this)
									},
									keySize: 8,
									ivSize: 0
								});

								function o() {
									for (var e = this._S, t = this._i, n = this._j, i = 0, r = 0; r < 4; r++) {
										t = (t + 1) % 256,
											n = (n + e[t]) % 256;
										var a = e[t];
										e[t] = e[n],
											e[n] = a,
											i |= e[(e[t] + e[n]) % 256] << 24 - 8 * r
									}
									return this._i = t,
										this._j = n,
										i
								}

								t.RC4 = i._createHelper(a);
								var s = r.RC4Drop = a.extend({
									cfg: a.cfg.extend({
										drop: 192
									}),
									_doReset: function () {
										a._doReset.call(this);
										for (var e = this.cfg.drop; e > 0; e--)
											o.call(this)
									}
								});
								t.RC4Drop = i._createHelper(s)
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.StreamCipher
									, r = t.algo
									, a = []
									, o = []
									, s = []
									, c = r.Rabbit = i.extend({
									_doReset: function () {
										for (var e = this._key.words, t = this.cfg.iv, n = 0; n < 4; n++)
											e[n] = 16711935 & (e[n] << 8 | e[n] >>> 24) | 4278255360 & (e[n] << 24 | e[n] >>> 8);
										var i = this._X = [e[0], e[3] << 16 | e[2] >>> 16, e[1], e[0] << 16 | e[3] >>> 16, e[2], e[1] << 16 | e[0] >>> 16, e[3], e[2] << 16 | e[1] >>> 16]
											,
											r = this._C = [e[2] << 16 | e[2] >>> 16, 4294901760 & e[0] | 65535 & e[1], e[3] << 16 | e[3] >>> 16, 4294901760 & e[1] | 65535 & e[2], e[0] << 16 | e[0] >>> 16, 4294901760 & e[2] | 65535 & e[3], e[1] << 16 | e[1] >>> 16, 4294901760 & e[3] | 65535 & e[0]];
										this._b = 0;
										for (n = 0; n < 4; n++)
											l.call(this);
										for (n = 0; n < 8; n++)
											r[n] ^= i[n + 4 & 7];
										if (t) {
											var a = t.words
												, o = a[0]
												, s = a[1]
												,
												c = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8)
												,
												u = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8)
												, d = c >>> 16 | 4294901760 & u
												, f = u << 16 | 65535 & c;
											r[0] ^= c,
												r[1] ^= d,
												r[2] ^= u,
												r[3] ^= f,
												r[4] ^= c,
												r[5] ^= d,
												r[6] ^= u,
												r[7] ^= f;
											for (n = 0; n < 4; n++)
												l.call(this)
										}
									},
									_doProcessBlock: function (e, t) {
										var n = this._X;
										l.call(this),
											a[0] = n[0] ^ n[5] >>> 16 ^ n[3] << 16,
											a[1] = n[2] ^ n[7] >>> 16 ^ n[5] << 16,
											a[2] = n[4] ^ n[1] >>> 16 ^ n[7] << 16,
											a[3] = n[6] ^ n[3] >>> 16 ^ n[1] << 16;
										for (var i = 0; i < 4; i++)
											a[i] = 16711935 & (a[i] << 8 | a[i] >>> 24) | 4278255360 & (a[i] << 24 | a[i] >>> 8),
												e[t + i] ^= a[i]
									},
									blockSize: 4,
									ivSize: 2
								});

								function l() {
									for (var e = this._X, t = this._C, n = 0; n < 8; n++)
										o[n] = t[n];
									t[0] = t[0] + 1295307597 + this._b | 0,
										t[1] = t[1] + 3545052371 + (t[0] >>> 0 < o[0] >>> 0 ? 1 : 0) | 0,
										t[2] = t[2] + 886263092 + (t[1] >>> 0 < o[1] >>> 0 ? 1 : 0) | 0,
										t[3] = t[3] + 1295307597 + (t[2] >>> 0 < o[2] >>> 0 ? 1 : 0) | 0,
										t[4] = t[4] + 3545052371 + (t[3] >>> 0 < o[3] >>> 0 ? 1 : 0) | 0,
										t[5] = t[5] + 886263092 + (t[4] >>> 0 < o[4] >>> 0 ? 1 : 0) | 0,
										t[6] = t[6] + 1295307597 + (t[5] >>> 0 < o[5] >>> 0 ? 1 : 0) | 0,
										t[7] = t[7] + 3545052371 + (t[6] >>> 0 < o[6] >>> 0 ? 1 : 0) | 0,
										this._b = t[7] >>> 0 < o[7] >>> 0 ? 1 : 0;
									for (n = 0; n < 8; n++) {
										var i = e[n] + t[n]
											, r = 65535 & i
											, a = i >>> 16
											, c = ((r * r >>> 17) + r * a >>> 15) + a * a
											, l = ((4294901760 & i) * i | 0) + ((65535 & i) * i | 0);
										s[n] = c ^ l
									}
									e[0] = s[0] + (s[7] << 16 | s[7] >>> 16) + (s[6] << 16 | s[6] >>> 16) | 0,
										e[1] = s[1] + (s[0] << 8 | s[0] >>> 24) + s[7] | 0,
										e[2] = s[2] + (s[1] << 16 | s[1] >>> 16) + (s[0] << 16 | s[0] >>> 16) | 0,
										e[3] = s[3] + (s[2] << 8 | s[2] >>> 24) + s[1] | 0,
										e[4] = s[4] + (s[3] << 16 | s[3] >>> 16) + (s[2] << 16 | s[2] >>> 16) | 0,
										e[5] = s[5] + (s[4] << 8 | s[4] >>> 24) + s[3] | 0,
										e[6] = s[6] + (s[5] << 16 | s[5] >>> 16) + (s[4] << 16 | s[4] >>> 16) | 0,
										e[7] = s[7] + (s[6] << 8 | s[6] >>> 24) + s[5] | 0
								}

								t.Rabbit = i._createHelper(c)
							}(),
							function () {
								var t = e
									, n = t.lib
									, i = n.StreamCipher
									, r = t.algo
									, a = []
									, o = []
									, s = []
									, c = r.RabbitLegacy = i.extend({
									_doReset: function () {
										var e = this._key.words
											, t = this.cfg.iv
											,
											n = this._X = [e[0], e[3] << 16 | e[2] >>> 16, e[1], e[0] << 16 | e[3] >>> 16, e[2], e[1] << 16 | e[0] >>> 16, e[3], e[2] << 16 | e[1] >>> 16]
											,
											i = this._C = [e[2] << 16 | e[2] >>> 16, 4294901760 & e[0] | 65535 & e[1], e[3] << 16 | e[3] >>> 16, 4294901760 & e[1] | 65535 & e[2], e[0] << 16 | e[0] >>> 16, 4294901760 & e[2] | 65535 & e[3], e[1] << 16 | e[1] >>> 16, 4294901760 & e[3] | 65535 & e[0]];
										this._b = 0;
										for (var r = 0; r < 4; r++)
											l.call(this);
										for (r = 0; r < 8; r++)
											i[r] ^= n[r + 4 & 7];
										if (t) {
											var a = t.words
												, o = a[0]
												, s = a[1]
												,
												c = 16711935 & (o << 8 | o >>> 24) | 4278255360 & (o << 24 | o >>> 8)
												,
												u = 16711935 & (s << 8 | s >>> 24) | 4278255360 & (s << 24 | s >>> 8)
												, d = c >>> 16 | 4294901760 & u
												, f = u << 16 | 65535 & c;
											i[0] ^= c,
												i[1] ^= d,
												i[2] ^= u,
												i[3] ^= f,
												i[4] ^= c,
												i[5] ^= d,
												i[6] ^= u,
												i[7] ^= f;
											for (r = 0; r < 4; r++)
												l.call(this)
										}
									},
									_doProcessBlock: function (e, t) {
										var n = this._X;
										l.call(this),
											a[0] = n[0] ^ n[5] >>> 16 ^ n[3] << 16,
											a[1] = n[2] ^ n[7] >>> 16 ^ n[5] << 16,
											a[2] = n[4] ^ n[1] >>> 16 ^ n[7] << 16,
											a[3] = n[6] ^ n[3] >>> 16 ^ n[1] << 16;
										for (var i = 0; i < 4; i++)
											a[i] = 16711935 & (a[i] << 8 | a[i] >>> 24) | 4278255360 & (a[i] << 24 | a[i] >>> 8),
												e[t + i] ^= a[i]
									},
									blockSize: 4,
									ivSize: 2
								});

								function l() {
									for (var e = this._X, t = this._C, n = 0; n < 8; n++)
										o[n] = t[n];
									t[0] = t[0] + 1295307597 + this._b | 0,
										t[1] = t[1] + 3545052371 + (t[0] >>> 0 < o[0] >>> 0 ? 1 : 0) | 0,
										t[2] = t[2] + 886263092 + (t[1] >>> 0 < o[1] >>> 0 ? 1 : 0) | 0,
										t[3] = t[3] + 1295307597 + (t[2] >>> 0 < o[2] >>> 0 ? 1 : 0) | 0,
										t[4] = t[4] + 3545052371 + (t[3] >>> 0 < o[3] >>> 0 ? 1 : 0) | 0,
										t[5] = t[5] + 886263092 + (t[4] >>> 0 < o[4] >>> 0 ? 1 : 0) | 0,
										t[6] = t[6] + 1295307597 + (t[5] >>> 0 < o[5] >>> 0 ? 1 : 0) | 0,
										t[7] = t[7] + 3545052371 + (t[6] >>> 0 < o[6] >>> 0 ? 1 : 0) | 0,
										this._b = t[7] >>> 0 < o[7] >>> 0 ? 1 : 0;
									for (n = 0; n < 8; n++) {
										var i = e[n] + t[n]
											, r = 65535 & i
											, a = i >>> 16
											, c = ((r * r >>> 17) + r * a >>> 15) + a * a
											, l = ((4294901760 & i) * i | 0) + ((65535 & i) * i | 0);
										s[n] = c ^ l
									}
									e[0] = s[0] + (s[7] << 16 | s[7] >>> 16) + (s[6] << 16 | s[6] >>> 16) | 0,
										e[1] = s[1] + (s[0] << 8 | s[0] >>> 24) + s[7] | 0,
										e[2] = s[2] + (s[1] << 16 | s[1] >>> 16) + (s[0] << 16 | s[0] >>> 16) | 0,
										e[3] = s[3] + (s[2] << 8 | s[2] >>> 24) + s[1] | 0,
										e[4] = s[4] + (s[3] << 16 | s[3] >>> 16) + (s[2] << 16 | s[2] >>> 16) | 0,
										e[5] = s[5] + (s[4] << 8 | s[4] >>> 24) + s[3] | 0,
										e[6] = s[6] + (s[5] << 16 | s[5] >>> 16) + (s[4] << 16 | s[4] >>> 16) | 0,
										e[7] = s[7] + (s[6] << 8 | s[6] >>> 24) + s[5] | 0
								}

								t.RabbitLegacy = i._createHelper(c)
							}(),
							e
					}
				))
		}
	).call(this, n("c8ba"))
}

可看出该方式为 webpack

加载器定位

定位加载器关键词

e[t].call(i.exports, i, i.exports, c),

上述位置断点断住后,刷新页面或点击底部输出结果可直接跳转至函数定义处

(function(e) {
    function t(t) {
        for (var a, o, r = t[0], c = t[1], l = t[2], u = 0, d = []; u < r.length; u++)
            o = r[u],
            Object.prototype.hasOwnProperty.call(n, o) && n[o] && d.push(n[o][0]),
            n[o] = 0;
        for (a in c)
            Object.prototype.hasOwnProperty.call(c, a) && (e[a] = c[a]);
        p && p(t);
        while (d.length)
            d.shift()();
        return s.push.apply(s, l || []),
        i()
    }
    function i() {
        for (var e, t = 0; t < s.length; t++) {
            for (var i = s[t], a = !0, o = 1; o < i.length; o++) {
                var r = i[o];
                0 !== n[r] && (a = !1)
            }
            a && (s.splice(t--, 1),
            e = c(c.s = i[0]))
        }
        return e
    }
    var a = {}
      , o = {
        app: 0
    }
      , n = {
        app: 0
    }
      , s = [];
    function r(e) {
        return c.p + "static/js/" + ({}[e] || e) + ".1714307742403.js"
    }
    function c(t) {
        if (a[t])
            return a[t].exports;
        var i = a[t] = {
            i: t,
            l: !1,
            exports: {}
        };
        return e[t].call(i.exports, i, i.exports, c),
        i.l = !0,
        i.exports
    }
    c.e = function(e) {
        var t = []
          , i = {
            "chunk-03c519f8": 1,
            "chunk-066e1416": 1,
            "chunk-09b14251": 1,
            "chunk-0b399ca8": 1,
            "chunk-17935fdc": 1,
            "chunk-1dc2aa85": 1,
            "chunk-24edbab4": 1,
            "chunk-26d38db2": 1,
            "chunk-26de5840": 1,
            "chunk-325566fc": 1,
            "chunk-6df3c5eb": 1,
            "chunk-9ba34ed8": 1,
            "chunk-339f8528": 1,
            "chunk-38f595c4": 1,
            "chunk-3947fab0": 1,
            "chunk-39d8d033": 1,
            "chunk-3cf204b2": 1,
            "chunk-3e51b23c": 1,
            "chunk-4a962e3a": 1,
            "chunk-4a96f72c": 1,
            "chunk-4e9d9b26": 1,
            "chunk-58ef1612": 1,
            "chunk-5cdd636e": 1,
            "chunk-523c4f94": 1,
            "chunk-59e2b158": 1,
            "chunk-61420a18": 1,
            "chunk-63e7f8a1": 1,
            "chunk-68fee9d1": 1,
            "chunk-6c8496ca": 1,
            "chunk-6f1b1cee": 1,
            "chunk-741b45f9": 1,
            "chunk-7564fd85": 1,
            "chunk-76855239": 1,
            "chunk-77d62707": 1,
            "chunk-7eb19054": 1,
            "chunk-a5c6acc4": 1,
            "chunk-adc0e75e": 1,
            "chunk-b297fcf6": 1,
            "chunk-b51903ec": 1,
            "chunk-c0b03f40": 1
        };
        o[e] ? t.push(o[e]) : 0 !== o[e] && i[e] && t.push(o[e] = new Promise((function(t, i) {
            for (var a = "static/css/" + ({}[e] || e) + ".1714307742403.css", n = c.p + a, s = document.getElementsByTagName("link"), r = 0; r < s.length; r++) {
                var l = s[r]
                  , u = l.getAttribute("data-href") || l.getAttribute("href");
                if ("stylesheet" === l.rel && (u === a || u === n))
                    return t()
            }
            var d = document.getElementsByTagName("style");
            for (r = 0; r < d.length; r++) {
                l = d[r],
                u = l.getAttribute("data-href");
                if (u === a || u === n)
                    return t()
            }
            var p = document.createElement("link");
            p.rel = "stylesheet",
            p.type = "text/css",
            p.onload = t,
            p.onerror = function(t) {
                var a = t && t.target && t.target.src || n
                  , s = new Error("Loading CSS chunk " + e + " failed.\n(" + a + ")");
                s.code = "CSS_CHUNK_LOAD_FAILED",
                s.request = a,
                delete o[e],
                p.parentNode.removeChild(p),
                i(s)
            }
            ,
            p.href = n;
            var m = document.getElementsByTagName("head")[0];
            m.appendChild(p)
        }
        )).then((function() {
            o[e] = 0
        }
        )));
        var a = n[e];
        if (0 !== a)
            if (a)
                t.push(a[2]);
            else {
                var s = new Promise((function(t, i) {
                    a = n[e] = [t, i]
                }
                ));
                t.push(a[2] = s);
                var l, u = document.createElement("script");
                u.charset = "utf-8",
                u.timeout = 120,
                c.nc && u.setAttribute("nonce", c.nc),
                u.src = r(e);
                var d = new Error;
                l = function(t) {
                    u.onerror = u.onload = null,
                    clearTimeout(p);
                    var i = n[e];
                    if (0 !== i) {
                        if (i) {
                            var a = t && ("load" === t.type ? "missing" : t.type)
                              , o = t && t.target && t.target.src;
                            d.message = "Loading chunk " + e + " failed.\n(" + a + ": " + o + ")",
                            d.name = "ChunkLoadError",
                            d.type = a,
                            d.request = o,
                            i[1](d)
                        }
                        n[e] = void 0
                    }
                }
                ;
                var p = setTimeout((function() {
                    l({
                        type: "timeout",
                        target: u
                    })
                }
                ), 12e4);
                u.onerror = u.onload = l,
                document.head.appendChild(u)
            }
        return Promise.all(t)
    }
    ,
    c.m = e,
    c.c = a,
    c.d = function(e, t, i) {
        c.o(e, t) || Object.defineProperty(e, t, {
            enumerable: !0,
            get: i
        })
    }
    ,
    c.r = function(e) {
        "undefined" !== typeof Symbol && Symbol.toStringTag && Object.defineProperty(e, Symbol.toStringTag, {
            value: "Module"
        }),
        Object.defineProperty(e, "__esModule", {
            value: !0
        })
    }
    ,
    c.t = function(e, t) {
        if (1 & t && (e = c(e)),
        8 & t)
            return e;
        if (4 & t && "object" === typeof e && e && e.__esModule)
            return e;
        var i = Object.create(null);
        if (c.r(i),
        Object.defineProperty(i, "default", {
            enumerable: !0,
            value: e
        }),
        2 & t && "string" != typeof e)
            for (var a in e)
                c.d(i, a, function(t) {
                    return e[t]
                }
                .bind(null, a));
        return i
    }
    ,
    c.n = function(e) {
        var t = e && e.__esModule ? function() {
            return e["default"]
        }
        : function() {
            return e
        }
        ;
        return c.d(t, "a", t),
        t
    }
    ,
    c.o = function(e, t) {
        return Object.prototype.hasOwnProperty.call(e, t)
    }
    ,
    c.p = "https://js.51jobcdn.com/we/",
    c.oe = function(e) {
        throw console.error(e),
        e
    }
    ;
    var l = window["webpackJsonp"] = window["webpackJsonp"] || []
      , u = l.push.bind(l);
    l.push = t,
    l = l.slice();
    for (var d = 0; d < l.length; d++)
        t(l[d]);
    var p = u;
    s.push([0, "chunk-vendors"]),
    i()
}
)({
	
});
重构加载器

 重新构建将加载器函数导出即可使用

var _util;
(function (e) {
    var a = {}
    , o = {
		app: 0
	}
    , n = {
		app: 0
	}
    , s = [];
    function c(t) {
        if (a[t])
            return a[t].exports;
        var i = a[t] = {
            i: t,
            l: !1,
            exports: {}
        };
        return e[t].call(i.exports, i, i.exports, c),
            i.l = !0,
            i.exports
    }
    _util = c;
}
)({
	
})
提取代码

将模块【8429】放入加载器中,然后将文件【chunk-vendors.1714307742403.js】另存进行备用

构建代码进行调试补充完善

console.log( _util( 8429 ) )

 那么到这里基本就结束了。
只需将上面webpack适配下 即可实现扣代码模块

结果测试 

_util( 8429 ).HmacSHA256( '1230', 'abfc8f9dcf8c3f3d8aa294ac5f2cf2cc7767e5592590f39c3f503271dd68562b' ).toString()

Python执行

iTime = time.time() * 1000
params = {
	'api_key': '51job',
	'timestamp': str( iTime ),
	'keyword': 'Python',
	'searchType': '2',
	'function': '',
	'industry': '',
	'jobArea': '000000',
	'jobArea2': '',
	'landmark': '',
	'metro': '',
	'salary': '',
	'workYear': '',
	'degree': '',
	'companyType': '',
	'companySize': '',
	'jobType': '',
	'issueDate': '',
	'sortType': '0',
	'pageNum': '1',
	'requestId': '',
	'pageSize': '20',
	'source': '1',
	'accountId': '',
	'pageCode': 'sou|sou|soulb',
}

jsDrive = openWithJs( 'sha256.js' )
uuid = jsDrive.call( 'getUUid' )
headers[ 'uuid' ] = uuid

query = urllib.parse.urlencode( params )
sign = jsDrive.call( 'getSign', f"/api/job/search-pc?{query}" )
headers[ 'sign' ] = sign

response = requests.get( url, params=params, cookies= cookies, headers=headers)
print( response )
print( response.text )

问题表述:

加上cookie之后,访问正常,长期请求则会返回异常页面,导致请求被中断

异常页面

<html>
<script>
    var arg1 = '7CF2F3A88BDEEE55E740AD0393843FE51664AD9C';
    var _0x4818 = ['\x63\x73\x4b\x48\x77\x71\x4d\x49', '\x5a\x73\x4b\x4a\x77\x72\x38\x56\x65\x41\x73\x79', '\x55\x63\x4b\x69\x4e\x38\x4f\x2f\x77\x70\x6c\x77\x4d\x41\x3d\x3d', '\x4a\x52\x38\x43\x54\x67\x3d\x3d', '\x59\x73\x4f\x6e\x62\x53\x45\x51\x77\x37\x6f\x7a\x77\x71\x5a\x4b\x65\x73\x4b\x55\x77\x37\x6b\x77\x58\x38\x4f\x52\x49\x51\x3d\x3d', '\x77\x37\x6f\x56\x53\x38\x4f\x53\x77\x6f\x50\x43\x6c\x33\x6a\x43\x68\x4d\x4b\x68\x77\x36\x48\x44\x6c\x73\x4b\x58\x77\x34\x73\x2f\x59\x73\x4f\x47', '\x66\x77\x56\x6d\x49\x31\x41\x74\x77\x70\x6c\x61\x59\x38\x4f\x74\x77\x35\x63\x4e\x66\x53\x67\x70\x77\x36\x4d\x3d', '\x4f\x63\x4f\x4e\x77\x72\x6a\x43\x71\x73\x4b\x78\x54\x47\x54\x43\x68\x73\x4f\x6a\x45\x57\x45\x38\x50\x63\x4f\x63\x4a\x38\x4b\x36', '\x55\x38\x4b\x35\x4c\x63\x4f\x74\x77\x70\x56\x30\x45\x4d\x4f\x6b\x77\x34\x37\x44\x72\x4d\x4f\x58', '\x48\x4d\x4f\x32\x77\x6f\x48\x43\x69\x4d\x4b\x39\x53\x6c\x58\x43\x6c\x63\x4f\x6f\x43\x31\x6b\x3d', '\x61\x73\x4b\x49\x77\x71\x4d\x44\x64\x67\x4d\x75\x50\x73\x4f\x4b\x42\x4d\x4b\x63\x77\x72\x72\x43\x74\x6b\x4c\x44\x72\x4d\x4b\x42\x77\x36\x34\x64', '\x77\x71\x49\x6d\x4d\x54\x30\x74\x77\x36\x52\x4e\x77\x35\x6b\x3d', '\x44\x4d\x4b\x63\x55\x30\x4a\x6d\x55\x77\x55\x76', '\x56\x6a\x48\x44\x6c\x4d\x4f\x48\x56\x63\x4f\x4e\x58\x33\x66\x44\x69\x63\x4b\x4a\x48\x51\x3d\x3d', '\x77\x71\x68\x42\x48\x38\x4b\x6e\x77\x34\x54\x44\x68\x53\x44\x44\x67\x4d\x4f\x64\x77\x72\x6a\x43\x6e\x63\x4f\x57\x77\x70\x68\x68\x4e\x38\x4b\x43\x47\x63\x4b\x71\x77\x36\x64\x48\x41\x55\x35\x2b\x77\x72\x67\x32\x4a\x63\x4b\x61\x77\x34\x49\x45\x4a\x63\x4f\x63\x77\x72\x52\x4a\x77\x6f\x5a\x30\x77\x71\x46\x39\x59\x67\x41\x56', '\x64\x7a\x64\x32\x77\x35\x62\x44\x6d\x33\x6a\x44\x70\x73\x4b\x33\x77\x70\x59\x3d', '\x77\x34\x50\x44\x67\x63\x4b\x58\x77\x6f\x33\x43\x6b\x63\x4b\x4c\x77\x72\x35\x71\x77\x72\x59\x3d', '\x77\x72\x4a\x4f\x54\x63\x4f\x51\x57\x4d\x4f\x67', '\x77\x71\x54\x44\x76\x63\x4f\x6a\x77\x34\x34\x37\x77\x72\x34\x3d', '\x77\x35\x58\x44\x71\x73\x4b\x68\x4d\x46\x31\x2f', '\x77\x72\x41\x79\x48\x73\x4f\x66\x77\x70\x70\x63', '\x4a\x33\x64\x56\x50\x63\x4f\x78\x4c\x67\x3d\x3d', '\x77\x72\x64\x48\x77\x37\x70\x39\x5a\x77\x3d\x3d', '\x77\x34\x72\x44\x6f\x38\x4b\x6d\x4e\x45\x77\x3d', '\x49\x4d\x4b\x41\x55\x6b\x42\x74', '\x77\x36\x62\x44\x72\x63\x4b\x51\x77\x70\x56\x48\x77\x70\x4e\x51\x77\x71\x55\x3d', '\x64\x38\x4f\x73\x57\x68\x41\x55\x77\x37\x59\x7a\x77\x72\x55\x3d', '\x77\x71\x6e\x43\x6b\x73\x4f\x65\x65\x7a\x72\x44\x68\x77\x3d\x3d', '\x55\x73\x4b\x6e\x49\x4d\x4b\x57\x56\x38\x4b\x2f', '\x77\x34\x7a\x44\x6f\x63\x4b\x38\x4e\x55\x5a\x76', '\x63\x38\x4f\x78\x5a\x68\x41\x4a\x77\x36\x73\x6b\x77\x71\x4a\x6a', '\x50\x63\x4b\x49\x77\x34\x6e\x43\x6b\x6b\x56\x62', '\x4b\x48\x67\x6f\x64\x4d\x4f\x32\x56\x51\x3d\x3d', '\x77\x70\x73\x6d\x77\x71\x76\x44\x6e\x47\x46\x71', '\x77\x71\x4c\x44\x74\x38\x4f\x6b\x77\x34\x63\x3d', '\x77\x37\x77\x31\x77\x34\x50\x43\x70\x73\x4f\x34\x77\x71\x41\x3d', '\x77\x71\x39\x46\x52\x73\x4f\x71\x57\x4d\x4f\x71', '\x62\x79\x42\x68\x77\x37\x72\x44\x6d\x33\x34\x3d', '\x4c\x48\x67\x2b\x53\x38\x4f\x74\x54\x77\x3d\x3d', '\x77\x71\x68\x4f\x77\x37\x31\x35\x64\x73\x4f\x48', '\x55\x38\x4f\x37\x56\x73\x4f\x30\x77\x71\x76\x44\x76\x63\x4b\x75\x4b\x73\x4f\x71\x58\x38\x4b\x72', '\x59\x69\x74\x74\x77\x35\x44\x44\x6e\x57\x6e\x44\x72\x41\x3d\x3d', '\x59\x4d\x4b\x49\x77\x71\x55\x55\x66\x67\x49\x6b', '\x61\x42\x37\x44\x6c\x4d\x4f\x44\x54\x51\x3d\x3d', '\x77\x70\x66\x44\x68\x38\x4f\x72\x77\x36\x6b\x6b', '\x77\x37\x76\x43\x71\x4d\x4f\x72\x59\x38\x4b\x41\x56\x6b\x35\x4f\x77\x70\x6e\x43\x75\x38\x4f\x61\x58\x73\x4b\x5a\x50\x33\x44\x43\x6c\x63\x4b\x79\x77\x36\x48\x44\x72\x51\x3d\x3d', '\x77\x6f\x77\x2b\x77\x36\x76\x44\x6d\x48\x70\x73\x77\x37\x52\x74\x77\x6f\x39\x38\x4c\x43\x37\x43\x69\x47\x37\x43\x6b\x73\x4f\x52\x54\x38\x4b\x6c\x57\x38\x4f\x35\x77\x72\x33\x44\x69\x38\x4f\x54\x48\x73\x4f\x44\x65\x48\x6a\x44\x6d\x63\x4b\x6c\x4a\x73\x4b\x71\x56\x41\x3d\x3d', '\x4e\x77\x56\x2b', '\x77\x37\x48\x44\x72\x63\x4b\x74\x77\x70\x4a\x61\x77\x70\x5a\x62', '\x77\x70\x51\x73\x77\x71\x76\x44\x69\x48\x70\x75\x77\x36\x49\x3d', '\x59\x4d\x4b\x55\x77\x71\x4d\x4a\x5a\x51\x3d\x3d', '\x4b\x48\x31\x56\x4b\x63\x4f\x71\x4b\x73\x4b\x31', '\x66\x51\x35\x73\x46\x55\x6b\x6b\x77\x70\x49\x3d', '\x77\x72\x76\x43\x72\x63\x4f\x42\x52\x38\x4b\x6b', '\x4d\x33\x77\x30\x66\x51\x3d\x3d', '\x77\x36\x78\x58\x77\x71\x50\x44\x76\x4d\x4f\x46\x77\x6f\x35\x64'];
    (function (_0x4c97f0, _0x1742fd) {
        var _0x4db1c = function (_0x48181e) {
            while (--_0x48181e) {
                _0x4c97f0['\x70\x75\x73\x68'](_0x4c97f0['\x73\x68\x69\x66\x74']());
            }
        };
        var _0x3cd6c6 = function () {
            var _0xb8360b = {
                '\x64\x61\x74\x61': {
                    '\x6b\x65\x79': '\x63\x6f\x6f\x6b\x69\x65',
                    '\x76\x61\x6c\x75\x65': '\x74\x69\x6d\x65\x6f\x75\x74'
                }, '\x73\x65\x74\x43\x6f\x6f\x6b\x69\x65': function (_0x20bf34, _0x3e840e, _0x5693d3, _0x5e8b26) {
                    _0x5e8b26 = _0x5e8b26 || {};
                    var _0xba82f0 = _0x3e840e + '\x3d' + _0x5693d3;
                    var _0x5afe31 = 0x0;
                    for (var _0x5afe31 = 0x0, _0x178627 = _0x20bf34['\x6c\x65\x6e\x67\x74\x68']; _0x5afe31 < _0x178627; _0x5afe31++) {
                        var _0x41b2ff = _0x20bf34[_0x5afe31];
                        _0xba82f0 += '\x3b\x20' + _0x41b2ff;
                        var _0xd79219 = _0x20bf34[_0x41b2ff];
                        _0x20bf34['\x70\x75\x73\x68'](_0xd79219);
                        _0x178627 = _0x20bf34['\x6c\x65\x6e\x67\x74\x68'];
                        if (_0xd79219 !== !![]) {
                            _0xba82f0 += '\x3d' + _0xd79219;
                        }
                    }
                    _0x5e8b26['\x63\x6f\x6f\x6b\x69\x65'] = _0xba82f0;
                }, '\x72\x65\x6d\x6f\x76\x65\x43\x6f\x6f\x6b\x69\x65': function () {
                    return '\x64\x65\x76';
                }, '\x67\x65\x74\x43\x6f\x6f\x6b\x69\x65': function (_0x4a11fe, _0x189946) {
                    _0x4a11fe = _0x4a11fe || function (_0x6259a2) {
                        return _0x6259a2;
                    };
                    var _0x25af93 = _0x4a11fe(new RegExp('\x28\x3f\x3a\x5e\x7c\x3b\x20\x29' + _0x189946['\x72\x65\x70\x6c\x61\x63\x65'](/([.$?*|{}()[]\/+^])/g, '\x24\x31') + '\x3d\x28\x5b\x5e\x3b\x5d\x2a\x29'));
                    var _0x52d57c = function (_0x105f59, _0x3fd789) {
                        _0x105f59(++_0x3fd789);
                    };
                    _0x52d57c(_0x4db1c, _0x1742fd);
                    return _0x25af93 ? decodeURIComponent(_0x25af93[0x1]) : undefined;
                }
            };
            var _0x4a2aed = function () {
                var _0x124d17 = new RegExp('\x5c\x77\x2b\x20\x2a\x5c\x28\x5c\x29\x20\x2a\x7b\x5c\x77\x2b\x20\x2a\x5b\x27\x7c\x22\x5d\x2e\x2b\x5b\x27\x7c\x22\x5d\x3b\x3f\x20\x2a\x7d');
                return _0x124d17['\x74\x65\x73\x74'](_0xb8360b['\x72\x65\x6d\x6f\x76\x65\x43\x6f\x6f\x6b\x69\x65']['\x74\x6f\x53\x74\x72\x69\x6e\x67']());
            };
            _0xb8360b['\x75\x70\x64\x61\x74\x65\x43\x6f\x6f\x6b\x69\x65'] = _0x4a2aed;
            var _0x2d67ec = '';
            var _0x120551 = _0xb8360b['\x75\x70\x64\x61\x74\x65\x43\x6f\x6f\x6b\x69\x65']();
            if (!_0x120551) {
                _0xb8360b['\x73\x65\x74\x43\x6f\x6f\x6b\x69\x65'](['\x2a'], '\x63\x6f\x75\x6e\x74\x65\x72', 0x1);
            } else if (_0x120551) {
                _0x2d67ec = _0xb8360b['\x67\x65\x74\x43\x6f\x6f\x6b\x69\x65'](null, '\x63\x6f\x75\x6e\x74\x65\x72');
            } else {
                _0xb8360b['\x72\x65\x6d\x6f\x76\x65\x43\x6f\x6f\x6b\x69\x65']();
            }
        };
        _0x3cd6c6();
    }(_0x4818, 0x15b));
    var _0x55f3 = function (_0x4c97f0, _0x1742fd) {
        var _0x4c97f0 = parseInt(_0x4c97f0, 0x10);
        var _0x48181e = _0x4818[_0x4c97f0];
        if (!_0x55f3['\x61\x74\x6f\x62\x50\x6f\x6c\x79\x66\x69\x6c\x6c\x41\x70\x70\x65\x6e\x64\x65\x64']) {
            (function () {
                var _0xdf49c6 = Function('\x72\x65\x74\x75\x72\x6e\x20\x28\x66\x75\x6e\x63\x74\x69\x6f\x6e\x20\x28\x29\x20' + '\x7b\x7d\x2e\x63\x6f\x6e\x73\x74\x72\x75\x63\x74\x6f\x72\x28\x22\x72\x65\x74\x75\x72\x6e\x20\x74\x68\x69\x73\x22\x29\x28\x29' + '\x29\x3b');
                var _0xb8360b = _0xdf49c6();
                var _0x389f44 = '\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4a\x4b\x4c\x4d\x4e\x4f\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5a\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6a\x6b\x6c\x6d\x6e\x6f\x70\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7a\x30\x31\x32\x33\x34\x35\x36\x37\x38\x39\x2b\x2f\x3d';
                _0xb8360b['\x61\x74\x6f\x62'] || (_0xb8360b['\x61\x74\x6f\x62'] = function (_0xba82f0) {
                    var _0xec6bb4 = String(_0xba82f0)['\x72\x65\x70\x6c\x61\x63\x65'](/=+$/, '');
                    for (var _0x1a0f04 = 0x0, _0x18c94e, _0x41b2ff, _0xd79219 = 0x0, _0x5792f7 = ''; _0x41b2ff = _0xec6bb4['\x63\x68\x61\x72\x41\x74'](_0xd79219++); ~_0x41b2ff && (_0x18c94e = _0x1a0f04 % 0x4 ? _0x18c94e * 0x40 + _0x41b2ff : _0x41b2ff, _0x1a0f04++ % 0x4) ? _0x5792f7 += String['\x66\x72\x6f\x6d\x43\x68\x61\x72\x43\x6f\x64\x65'](0xff & _0x18c94e >> (-0x2 * _0x1a0f04 & 0x6)) : 0x0) {
                        _0x41b2ff = _0x389f44['\x69\x6e\x64\x65\x78\x4f\x66'](_0x41b2ff);
                    }
                    return _0x5792f7;
                });
            }());
            _0x55f3['\x61\x74\x6f\x62\x50\x6f\x6c\x79\x66\x69\x6c\x6c\x41\x70\x70\x65\x6e\x64\x65\x64'] = !![];
        }
        if (!_0x55f3['\x72\x63\x34']) {
            var _0x232678 = function (_0x401af1, _0x532ac0) {
                var _0x45079a = [], _0x52d57c = 0x0, _0x105f59, _0x3fd789 = '', _0x4a2aed = '';
                _0x401af1 = atob(_0x401af1);
                for (var _0x124d17 = 0x0, _0x1b9115 = _0x401af1['\x6c\x65\x6e\x67\x74\x68']; _0x124d17 < _0x1b9115; _0x124d17++) {
                    _0x4a2aed += '\x25' + ('\x30\x30' + _0x401af1['\x63\x68\x61\x72\x43\x6f\x64\x65\x41\x74'](_0x124d17)['\x74\x6f\x53\x74\x72\x69\x6e\x67'](0x10))['\x73\x6c\x69\x63\x65'](-0x2);
                }
                _0x401af1 = decodeURIComponent(_0x4a2aed);
                for (var _0x2d67ec = 0x0; _0x2d67ec < 0x100; _0x2d67ec++) {
                    _0x45079a[_0x2d67ec] = _0x2d67ec;
                }
                for (_0x2d67ec = 0x0; _0x2d67ec < 0x100; _0x2d67ec++) {
                    _0x52d57c = (_0x52d57c + _0x45079a[_0x2d67ec] + _0x532ac0['\x63\x68\x61\x72\x43\x6f\x64\x65\x41\x74'](_0x2d67ec % _0x532ac0['\x6c\x65\x6e\x67\x74\x68'])) % 0x100;
                    _0x105f59 = _0x45079a[_0x2d67ec];
                    _0x45079a[_0x2d67ec] = _0x45079a[_0x52d57c];
                    _0x45079a[_0x52d57c] = _0x105f59;
                }
                _0x2d67ec = 0x0;
                _0x52d57c = 0x0;
                for (var _0x4e5ce2 = 0x0; _0x4e5ce2 < _0x401af1['\x6c\x65\x6e\x67\x74\x68']; _0x4e5ce2++) {
                    _0x2d67ec = (_0x2d67ec + 0x1) % 0x100;
                    _0x52d57c = (_0x52d57c + _0x45079a[_0x2d67ec]) % 0x100;
                    _0x105f59 = _0x45079a[_0x2d67ec];
                    _0x45079a[_0x2d67ec] = _0x45079a[_0x52d57c];
                    _0x45079a[_0x52d57c] = _0x105f59;
                    _0x3fd789 += String['\x66\x72\x6f\x6d\x43\x68\x61\x72\x43\x6f\x64\x65'](_0x401af1['\x63\x68\x61\x72\x43\x6f\x64\x65\x41\x74'](_0x4e5ce2) ^ _0x45079a[(_0x45079a[_0x2d67ec] + _0x45079a[_0x52d57c]) % 0x100]);
                }
                return _0x3fd789;
            };
            _0x55f3['\x72\x63\x34'] = _0x232678;
        }
        if (!_0x55f3['\x64\x61\x74\x61']) {
            _0x55f3['\x64\x61\x74\x61'] = {};
        }
        if (_0x55f3['\x64\x61\x74\x61'][_0x4c97f0] === undefined) {
            if (!_0x55f3['\x6f\x6e\x63\x65']) {
                var _0x5f325c = function (_0x23a392) {
                    this['\x72\x63\x34\x42\x79\x74\x65\x73'] = _0x23a392;
                    this['\x73\x74\x61\x74\x65\x73'] = [0x1, 0x0, 0x0];
                    this['\x6e\x65\x77\x53\x74\x61\x74\x65'] = function () {
                        return '\x6e\x65\x77\x53\x74\x61\x74\x65';
                    };
                    this['\x66\x69\x72\x73\x74\x53\x74\x61\x74\x65'] = '\x5c\x77\x2b\x20\x2a\x5c\x28\x5c\x29\x20\x2a\x7b\x5c\x77\x2b\x20\x2a';
                    this['\x73\x65\x63\x6f\x6e\x64\x53\x74\x61\x74\x65'] = '\x5b\x27\x7c\x22\x5d\x2e\x2b\x5b\x27\x7c\x22\x5d\x3b\x3f\x20\x2a\x7d';
                };
                _0x5f325c['\x70\x72\x6f\x74\x6f\x74\x79\x70\x65']['\x63\x68\x65\x63\x6b\x53\x74\x61\x74\x65'] = function () {
                    var _0x19f809 = new RegExp(this['\x66\x69\x72\x73\x74\x53\x74\x61\x74\x65'] + this['\x73\x65\x63\x6f\x6e\x64\x53\x74\x61\x74\x65']);
                    return this['\x72\x75\x6e\x53\x74\x61\x74\x65'](_0x19f809['\x74\x65\x73\x74'](this['\x6e\x65\x77\x53\x74\x61\x74\x65']['\x74\x6f\x53\x74\x72\x69\x6e\x67']()) ? --this['\x73\x74\x61\x74\x65\x73'][0x1] : --this['\x73\x74\x61\x74\x65\x73'][0x0]);
                };
                _0x5f325c['\x70\x72\x6f\x74\x6f\x74\x79\x70\x65']['\x72\x75\x6e\x53\x74\x61\x74\x65'] = function (_0x4380bd) {
                    if (!Boolean(~_0x4380bd)) {
                        return _0x4380bd;
                    }
                    return this['\x67\x65\x74\x53\x74\x61\x74\x65'](this['\x72\x63\x34\x42\x79\x74\x65\x73']);
                };
                _0x5f325c['\x70\x72\x6f\x74\x6f\x74\x79\x70\x65']['\x67\x65\x74\x53\x74\x61\x74\x65'] = function (_0x58d85e) {
                    for (var _0x1c9f5b = 0x0, _0x1ce9e0 = this['\x73\x74\x61\x74\x65\x73']['\x6c\x65\x6e\x67\x74\x68']; _0x1c9f5b < _0x1ce9e0; _0x1c9f5b++) {
                        this['\x73\x74\x61\x74\x65\x73']['\x70\x75\x73\x68'](Math['\x72\x6f\x75\x6e\x64'](Math['\x72\x61\x6e\x64\x6f\x6d']()));
                        _0x1ce9e0 = this['\x73\x74\x61\x74\x65\x73']['\x6c\x65\x6e\x67\x74\x68'];
                    }
                    return _0x58d85e(this['\x73\x74\x61\x74\x65\x73'][0x0]);
                };
                new _0x5f325c(_0x55f3)['\x63\x68\x65\x63\x6b\x53\x74\x61\x74\x65']();
                _0x55f3['\x6f\x6e\x63\x65'] = !![];
            }
            _0x48181e = _0x55f3['\x72\x63\x34'](_0x48181e, _0x1742fd);
            _0x55f3['\x64\x61\x74\x61'][_0x4c97f0] = _0x48181e;
        } else {
            _0x48181e = _0x55f3['\x64\x61\x74\x61'][_0x4c97f0];
        }
        return _0x48181e;
    };
    var arg3 = null;
    var arg4 = null;
    var arg5 = null;
    var arg6 = null;
    var arg7 = null;
    var arg8 = null;
    var arg9 = null;
    var arg10 = null;
    var l = function () {
        while (window[_0x55f3('0x1', '\x58\x4d\x57\x5e')] || window['\x5f\x5f\x70\x68\x61\x6e\x74\x6f\x6d\x61\x73']) {
        }
        ;var _0x5e8b26 = _0x55f3('0x3', '\x6a\x53\x31\x59');
        String[_0x55f3('0x5', '\x6e\x5d\x66\x52')][_0x55f3('0x6', '\x50\x67\x35\x34')] = function (_0x4e08d8) {
            var _0x5a5d3b = '';
            for (var _0xe89588 = 0x0; _0xe89588 < this[_0x55f3('0x8', '\x29\x68\x52\x63')] && _0xe89588 < _0x4e08d8[_0x55f3('0xa', '\x6a\x45\x26\x5e')]; _0xe89588 += 0x2) {
                var _0x401af1 = parseInt(this[_0x55f3('0xb', '\x56\x32\x4b\x45')](_0xe89588, _0xe89588 + 0x2), 0x10);
                var _0x105f59 = parseInt(_0x4e08d8[_0x55f3('0xd', '\x58\x4d\x57\x5e')](_0xe89588, _0xe89588 + 0x2), 0x10);
                var _0x189e2c = (_0x401af1 ^ _0x105f59)[_0x55f3('0xf', '\x57\x31\x46\x45')](0x10);
                if (_0x189e2c[_0x55f3('0x11', '\x4d\x47\x72\x76')] == 0x1) {
                    _0x189e2c = '\x30' + _0x189e2c;
                }
                _0x5a5d3b += _0x189e2c;
            }
            return _0x5a5d3b;
        };
        String['\x70\x72\x6f\x74\x6f\x74\x79\x70\x65'][_0x55f3('0x14', '\x5a\x2a\x44\x4d')] = function () {
            var _0x4b082b = [0xf, 0x23, 0x1d, 0x18, 0x21, 0x10, 0x1, 0x26, 0xa, 0x9, 0x13, 0x1f, 0x28, 0x1b, 0x16, 0x17, 0x19, 0xd, 0x6, 0xb, 0x27, 0x12, 0x14, 0x8, 0xe, 0x15, 0x20, 0x1a, 0x2, 0x1e, 0x7, 0x4, 0x11, 0x5, 0x3, 0x1c, 0x22, 0x25, 0xc, 0x24];
            var _0x4da0dc = [];
            var _0x12605e = '';
            for (var _0x20a7bf = 0x0; _0x20a7bf < this['\x6c\x65\x6e\x67\x74\x68']; _0x20a7bf++) {
                var _0x385ee3 = this[_0x20a7bf];
                for (var _0x217721 = 0x0; _0x217721 < _0x4b082b[_0x55f3('0x16', '\x61\x48\x2a\x4e')]; _0x217721++) {
                    if (_0x4b082b[_0x217721] == _0x20a7bf + 0x1) {
                        _0x4da0dc[_0x217721] = _0x385ee3;
                    }
                }
            }
            _0x12605e = _0x4da0dc['\x6a\x6f\x69\x6e']('');
            return _0x12605e;
        };
        var _0x23a392 = arg1[_0x55f3('0x19', '\x50\x67\x35\x34')]();
        arg2 = _0x23a392[_0x55f3('0x1b', '\x7a\x35\x4f\x26')](_0x5e8b26);
        setTimeout('\x72\x65\x6c\x6f\x61\x64\x28\x61\x72\x67\x32\x29', 0x2);
    };
    var _0x4db1c = function () {
        function _0x355d23(_0x450614) {
            if (('' + _0x450614 / _0x450614)[_0x55f3('0x1c', '\x56\x32\x4b\x45')] !== 0x1 || _0x450614 % 0x14 === 0x0) {
                (function () {
                }[_0x55f3('0x1d', '\x43\x4e\x55\x59')]((undefined + '')[0x2] + (!![] + '')[0x3] + ([][_0x55f3('0x1e', '\x77\x38\x50\x52')]() + '')[0x2] + (undefined + '')[0x0] + (![] + [0x0] + String)[0x14] + (![] + [0x0] + String)[0x14] + (!![] + '')[0x3] + (!![] + '')[0x1])());
            } else {
                (function () {
                }['\x63\x6f\x6e\x73\x74\x72\x75\x63\x74\x6f\x72']((undefined + '')[0x2] + (!![] + '')[0x3] + ([][_0x55f3('0x1f', '\x4c\x24\x28\x44')]() + '')[0x2] + (undefined + '')[0x0] + (![] + [0x0] + String)[0x14] + (![] + [0x0] + String)[0x14] + (!![] + '')[0x3] + (!![] + '')[0x1])());
            }
            _0x355d23(++_0x450614);
        }

        try {
            _0x355d23(0x0);
        } catch (_0x54c483) {
        }
    };
    if (function () {
        var _0x470d8f = function () {
            var _0x4c97f0 = !![];
            return function (_0x1742fd, _0x4db1c) {
                var _0x48181e = _0x4c97f0 ? function () {
                    if (_0x4db1c) {
                        var _0x55f3be = _0x4db1c['\x61\x70\x70\x6c\x79'](_0x1742fd, arguments);
                        _0x4db1c = null;
                        return _0x55f3be;
                    }
                } : function () {
                };
                _0x4c97f0 = ![];
                return _0x48181e;
            };
        }();
        var _0x501fd7 = _0x470d8f(this, function () {
            var _0x4c97f0 = function () {
                return '\x64\x65\x76';
            }, _0x1742fd = function () {
                return '\x77\x69\x6e\x64\x6f\x77';
            };
            var _0x55f3be = function () {
                var _0x3ad9a1 = new RegExp('\x5c\x77\x2b\x20\x2a\x5c\x28\x5c\x29\x20\x2a\x7b\x5c\x77\x2b\x20\x2a\x5b\x27\x7c\x22\x5d\x2e\x2b\x5b\x27\x7c\x22\x5d\x3b\x3f\x20\x2a\x7d');
                return !_0x3ad9a1['\x74\x65\x73\x74'](_0x4c97f0['\x74\x6f\x53\x74\x72\x69\x6e\x67']());
            };
            var _0x1b93ad = function () {
                var _0x20bf34 = new RegExp('\x28\x5c\x5c\x5b\x78\x7c\x75\x5d\x28\x5c\x77\x29\x7b\x32\x2c\x34\x7d\x29\x2b');
                return _0x20bf34['\x74\x65\x73\x74'](_0x1742fd['\x74\x6f\x53\x74\x72\x69\x6e\x67']());
            };
            var _0x5afe31 = function (_0x178627) {
                var _0x1a0f04 = ~-0x1 >> 0x1 + 0xff % 0x0;
                if (_0x178627['\x69\x6e\x64\x65\x78\x4f\x66']('\x69' === _0x1a0f04)) {
                    _0xd79219(_0x178627);
                }
            };
            var _0xd79219 = function (_0x5792f7) {
                var _0x4e08d8 = ~-0x4 >> 0x1 + 0xff % 0x0;
                if (_0x5792f7['\x69\x6e\x64\x65\x78\x4f\x66']((!![] + '')[0x3]) !== _0x4e08d8) {
                    _0x5afe31(_0x5792f7);
                }
            };
            if (!_0x55f3be()) {
                if (!_0x1b93ad()) {
                    _0x5afe31('\x69\x6e\x64\u0435\x78\x4f\x66');
                } else {
                    _0x5afe31('\x69\x6e\x64\x65\x78\x4f\x66');
                }
            } else {
                _0x5afe31('\x69\x6e\x64\u0435\x78\x4f\x66');
            }
        });
        _0x501fd7();
        var _0x3a394d = function () {
            var _0x1ab151 = !![];
            return function (_0x372617, _0x42d229) {
                var _0x3b3503 = _0x1ab151 ? function () {
                    if (_0x42d229) {
                        var _0x7086d9 = _0x42d229[_0x55f3('0x21', '\x4b\x4e\x29\x46')](_0x372617, arguments);
                        _0x42d229 = null;
                        return _0x7086d9;
                    }
                } : function () {
                };
                _0x1ab151 = ![];
                return _0x3b3503;
            };
        }();
        var _0x5b6351 = _0x3a394d(this, function () {
            var _0x46cbaa = Function(_0x55f3('0x22', '\x26\x68\x5a\x59') + _0x55f3('0x23', '\x61\x48\x2a\x4e') + '\x29\x3b');
            var _0x1766ff = function () {
            };
            var _0x9b5e29 = _0x46cbaa();
            _0x9b5e29[_0x55f3('0x26', '\x61\x48\x2a\x4e')]['\x6c\x6f\x67'] = _0x1766ff;
            _0x9b5e29[_0x55f3('0x29', '\x56\x25\x59\x52')][_0x55f3('0x2a', '\x50\x5e\x45\x71')] = _0x1766ff;
            _0x9b5e29[_0x55f3('0x2c', '\x6c\x67\x4d\x30')][_0x55f3('0x2d', '\x4c\x24\x28\x44')] = _0x1766ff;
            _0x9b5e29[_0x55f3('0x2f', '\x43\x5a\x63\x38')][_0x55f3('0x30', '\x57\x75\x36\x25')] = _0x1766ff;
        });
        _0x5b6351();
        try {
            return !!window['\x61\x64\x64\x45\x76\x65\x6e\x74\x4c\x69\x73\x74\x65\x6e\x65\x72'];
        } catch (_0x35538d) {
            return ![];
        }
    }()) {
        document[_0x55f3('0x33', '\x56\x25\x59\x52')](_0x55f3('0x34', '\x79\x41\x70\x7a'), l, ![]);
    } else {
        document[_0x55f3('0x36', '\x79\x41\x70\x7a')](_0x55f3('0x37', '\x4c\x24\x28\x44'), l);
    }
    _0x4db1c();
    setInterval(function () {
        _0x4db1c();
    }, 0xfa0);

    function setCookie(name, value) {
        var expiredate = new Date();
        expiredate.setTime(expiredate.getTime() + (3600 * 1000));
        document.cookie = name + "=" + value + ";expires=" + expiredate.toGMTString() + ";max-age=3600;path=/";
    }

    function reload(x) {
        setCookie("acw_sc__v2", x);
        document.location.reload();
    }
</script>
</html>

这里发现关键点:acw_sc__v2,在cookie中也发现该关键词

多次测试发现就是 acw_sc__v2 影响结果。

如何解密生成:acw_sc__v2

  • 20
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript逆向工程涉及到逆向分析、代码还原、代码修改等多个方面,其中Webpack作为一个重要的静态模块打包器,也是逆向工程中需要重点关注的一部分。以下是一些关于Webpack逆向的笔记: 1. Webpack的打包过程是从入口文件开始的,Webpack会递归地遍历所有依赖模块,并将它们打包成一个或多个Bundle文件。因此,逆向工程的第一步就是找到Webpack打包的入口文件。 2. 在入口文件中,Webpack会通过require或import语句加载其他模块,并递归地遍历所有依赖模块。因此,我们可以通过分析入口文件来了解应用的整体结构和模块依赖关系。 3. 在Webpack的打包过程中,每个模块都会被赋予一个唯一的标识符,这个标识符可以通过module.id来获取。因此,我们可以通过分析打包后的代码,来了解每个模块的标识符和依赖关系。 4. 在Webpack的打包过程中,Loader和Plugin是非常重要的扩展机制,它们可以对模块进行转换和优化。因此,我们可以通过分析Loader和Plugin的源代码,来了解它们的作用和实现原理。 5. 在逆向工程中,我们可以使用Webpack的source-map选项来生成源映射文件,从而方便我们进行代码还原和调试。同时,我们也可以使用Webpack的devtool选项来设置不同的调试工具,以便更好地进行逆向分析和调试。 总的来说,Webpack作为静态模块打包器,在JavaScript逆向工程中扮演着重要的角色。通过对Webpack逆向分析,我们可以更加深入地了解应用的整体结构和模块依赖关系,从而更好地进行代码还原和调试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值