开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 434|回复: 3
收起左侧

[完成] 软件返回数据解密问题

 关闭 [复制链接]
结帖率:83% (53/64)
发表于 2024-5-20 14:50:54 | 显示全部楼层 |阅读模式   江苏省镇江市
5精币
今天遇到一个软件,平时我要用软件想白嫖一下就抓包改下数据就可以了,今天不知道为什么这个软件不行,都是加密的   {"msg":"参数解密失败","data":{"key":"350A3A600D080355D467D728","encryptType":0,"  这个key是不是就是密钥

软件链接 大佬可以练练手:https://wwt.lanzouu.com/i3KlW1y9p53i

1

1


如果改一下数据会出现一个key我不知道是什么!

123456789.png

post网址 :http://114.132.125.146/webgateway.html
date:I47F8Z7K0PfWPX+q9BWaJM6VI83ybEppJ0UFSzaMEXkUX6QzTJKLr1gJaocqfudxz3Febl/p1ma2nMm6P8wrPlj/vqpruZM/uE4zvK1tTjrh1E7BYcQM6VwpiafCUf4RnDJF0yxJ9H24Tk/L8g1UPceuWhlMZHbBAr9F5+hpa2NxbSN5NW9kSsyGO1gCD36PEKBR3A4jeI+9THawFjO6VUceBq4JRRmw
head:
User-Agent: Mozilla/4.0 (compatible; MSIE 9.0; Windows NT 6.1)
APPID: 489
init: 1
Host: 114.132.125.146
Content-Length: 224






最佳答案

查看完整内容

{"appid":489,"wtype":1,"timestamp":"1716184804058","data":[{"key":"350A3A600D080355D467D7282A449E5B","version":"1.0"}],"sign":"3bf2b4965ebb6c0de6c4a6b86aa1e2e5"} des ecb模式 350A3A600D080355D467D728
结帖率:64% (9/14)

签到天数: 21 天

发表于 2024-5-20 14:50:55 | 显示全部楼层   北京市北京市
{"appid":489,"wtype":1,"timestamp":"1716184804058","data":[{"key":"350A3A600D080355D467D7282A449E5B","version":"1.0"}],"sign":"3bf2b4965ebb6c0de6c4a6b86aa1e2e5"}

des  ecb模式  350A3A600D080355D467D728
回复

使用道具 举报

结帖率:64% (9/14)

签到天数: 21 天

发表于 2024-5-20 16:28:01 | 显示全部楼层   北京市北京市
加密方式:

AES/ECB/PKCS5Padding
DES/ECB/PKCS5Padding
加密KEY,加密盐,验证初始化的时候为软件密钥前24位,验证初始化成功后返回privateKey,privateSalt,encryptType为0使用DES,为1使用AES
加密KEY用来封包算法加密,加密盐用来sign签名校验
服务器地址:https://37ax.cn/webgateway.html
发送示例:
在封包头部添加,APPID参数,值为你的软件编号ID
加密(JSON数据)
{
“appid”:31,
“wtype”:1,
“timestamp”:”1557585277619”,
“data”:[
{
     "key":"2278D892BEA1BF3C3B28F14AF66025AA",
     "version":"1.1"
}
],
“sign”:”04f1fe750d44a0bf0b40f3f73c72638a”
}
//sign签名方式MD5(_appid + json中的data字段 + 加密盐 + json中的timestamp)
//比如上面的包就是 MD5(31{“key”:”2278D892BEA1BF3C3B28F14AF66025AA”,”version”:”1.1”}2278D892BEA1BF3C3B28F14A1557585277619)
appid 参数必须,软件id
wtype 必须,要做什么操作
timestamp 必须,现行时间戳13位,不得与北京时间相差10秒
如下
POST /webgateway.html HTTP/1.1
Connection: Keep-Alive
Content-Type: application/x-www-form-urlencoded; Charset=UTF-8
Accept: /
Accept-Language: zh-cn
Referer: https://37ax.cn/webgateway.html
User-Agent: Mozilla/4.0 (compatible; MSIE 9.0; Windows NT 6.1)
APPID: 35 //每个包必须带上软件编号
init: 1 //初始化包需要带上init为1 其他包不需要
Host: 37ax.cn
Content-Length: 224
iFiSjAQuCzJxphJrPkMmadkh2tQU9ViMq7wp+aZjO/pukUVXq7CqdTIPZFLKkZDBob8YaROLGDWZMwkxeJAQ2/qTZX+zgJqK7f54a8ucIhaye44vNpH6jRWk7Wnj/aig/RItvC2NJjNr6dTUO8EC8fKaqNDKrRcjSidgEAfCTT5uQxcnr5WSuTjTSVC0hRwdiBX929I9iXH6sNVek8kpzQ8RKbLhHh22

返回示例:
xFsvTYp3fbH4+CfU/C7jyEQAfO4wI1qf7ydQR7pL+FgECzXQnr0X9eA0+6kpR9GhUrB+9UxefCM=
解密后为JSON字符串,如下
{“msg”:”版本不存在”,”data”:[],”code”:-10004}
一般调用成功 返回code值0,返回数据存放在data字段,调用失败返回负数 msg为失败原因  这不都告诉你 怎么加密的吗
回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 21 天

发表于 2024-5-20 18:28:58 | 显示全部楼层   湖南省娄底市

加密模式 DES/CBC/PCSK7
IV 内置了 Key是 350A3A600D080355D467D728
[JavaScript] 纯文本查看 复制代码
var CryptoJS = CryptoJS || function(u, l) {
        var d = {}, n = d.lib = {}, p = function() {}, s = n.Base = {
            extend: function(a) {
                p.prototype = this;
                var c = new p;
                a && c.mixIn(a);
                c.hasOwnProperty("init") || (c.init = function() {
                    c.$super.init.apply(this, arguments)
                });
                c.init.prototype = c;
                c.$super = this;
                return c
            },
            create: function() {
                var a = this.extend();
                a.init.apply(a, arguments);
                return a
            },
            init: function() {},
            mixIn: function(a) {
                for (var c in a) a.hasOwnProperty(c) && (this[c] = a[c]);
                a.hasOwnProperty("toString") && (this.toString = a.toString)
            },
            clone: function() {
                return this.init.prototype.extend(this)
            }
        }, q = n.WordArray = s.extend({
            init: function(a, c) {
                a = this.words = a || [];
                this.sigBytes = c != l ? c : 4 * a.length
            },
            toString: function(a) {
                return (a || v).stringify(this)
            },
            concat: function(a) {
                var c = this.words,
                    m = a.words,
                    f = this.sigBytes;
                a = a.sigBytes;
                this.clamp();
                if (f % 4) for (var t = 0; t < a; t++) c[f + t >>> 2] |= (m[t >>> 2] >>> 24 - 8 * (t % 4) & 255) << 24 - 8 * ((f + t) % 4);
                else if (65535 < m.length) for (t = 0; t < a; t += 4) c[f + t >>> 2] = m[t >>> 2];
                else c.push.apply(c, m);
                this.sigBytes += a;
                return this
            },
            clamp: function() {
                var a = this.words,
                    c = this.sigBytes;
                a[c >>> 2] &= 4294967295 << 32 - 8 * (c % 4);
                a.length = u.ceil(c / 4)
            },
            clone: function() {
                var a = s.clone.call(this);
                a.words = this.words.slice(0);
                return a
            },
            random: function(a) {
                for (var c = [], m = 0; m < a; m += 4) c.push(4294967296 * u.random() | 0);
                return new q.init(c, a)
            }
        }),
            w = d.enc = {}, v = w.Hex = {
                stringify: function(a) {
                    var c = a.words;
                    a = a.sigBytes;
                    for (var m = [], f = 0; f < a; f++) {
                        var t = c[f >>> 2] >>> 24 - 8 * (f % 4) & 255;
                        m.push((t >>> 4).toString(16));
                        m.push((t & 15).toString(16))
                    }
                    return m.join("")
                },
                parse: function(a) {
                    for (var c = a.length, m = [], f = 0; f < c; f += 2) m[f >>> 3] |= parseInt(a.substr(f, 2), 16) << 24 - 4 * (f % 8);
                    return new q.init(m, c / 2)
                }
            }, b = w.Latin1 = {
                stringify: function(a) {
                    var c = a.words;
                    a = a.sigBytes;
                    for (var m = [], f = 0; f < a; f++) m.push(String.fromCharCode(c[f >>> 2] >>> 24 - 8 * (f % 4) & 255));
                    return m.join("")
                },
                parse: function(a) {
                    for (var c = a.length, m = [], f = 0; f < c; f++) m[f >>> 2] |= (a.charCodeAt(f) & 255) << 24 - 8 * (f % 4);
                    return new q.init(m, c)
                }
            }, x = w.Utf8 = {
                stringify: function(a) {
                    try {
                        return decodeURIComponent(escape(b.stringify(a)))
                    } catch (c) {
                        throw Error("Malformed UTF-8 data");
                    }
                },
                parse: function(a) {
                    return b.parse(unescape(encodeURIComponent(a)))
                }
            }, r = n.BufferedBlockAlgorithm = s.extend({
                reset: function() {
                    this._data = new q.init;
                    this._nDataBytes = 0
                },
                _append: function(a) {
                    "string" == typeof a && (a = x.parse(a));
                    this._data.concat(a);
                    this._nDataBytes += a.sigBytes
                },
                _process: function(a) {
                    var c = this._data,
                        m = c.words,
                        f = c.sigBytes,
                        t = this.blockSize,
                        b = f / (4 * t),
                        b = a ? u.ceil(b) : u.max((b | 0) - this._minBufferSize, 0);
                    a = b * t;
                    f = u.min(4 * a, f);
                    if (a) {
                        for (var e = 0; e < a; e += t) this._doProcessBlock(m, e);
                        e = m.splice(0, a);
                        c.sigBytes -= f
                    }
                    return new q.init(e, f)
                },
                clone: function() {
                    var a = s.clone.call(this);
                    a._data = this._data.clone();
                    return a
                },
                _minBufferSize: 0
            });
        n.Hasher = r.extend({
            cfg: s.extend(),
            init: function(a) {
                this.cfg = this.cfg.extend(a);
                this.reset()
            },
            reset: function() {
                r.reset.call(this);
                this._doReset()
            },
            update: function(a) {
                this._append(a);
                this._process();
                return this
            },
            finalize: function(a) {
                a && this._append(a);
                return this._doFinalize()
            },
            blockSize: 16,
            _createHelper: function(a) {
                return function(c, m) {
                    return (new a.init(m)).finalize(c)
                }
            },
            _createHmacHelper: function(a) {
                return function(c, m) {
                    return (new e.HMAC.init(a, m)).finalize(c)
                }
            }
        });
        var e = d.algo = {};
        return d
    }(Math);
(function() {
    var u = CryptoJS,
        l = u.lib.WordArray;
    u.enc.Base64 = {
        stringify: function(d) {
            var n = d.words,
                l = d.sigBytes,
                s = this._map;
            d.clamp();
            d = [];
            for (var q = 0; q < l; q += 3) for (var w = (n[q >>> 2] >>> 24 - 8 * (q % 4) & 255) << 16 | (n[q + 1 >>> 2] >>> 24 - 8 * ((q + 1) % 4) & 255) << 8 | n[q + 2 >>> 2] >>> 24 - 8 * ((q + 2) % 4) & 255, v = 0; 4 > v && q + 0.75 * v < l; v++) d.push(s.charAt(w >>> 6 * (3 - v) & 63));
            if (n = s.charAt(64)) for (; d.length % 4;) d.push(n);
            return d.join("")
        },
        parse: function(d) {
            var n = d.length,
                p = this._map,
                s = p.charAt(64);
            s && (s = d.indexOf(s), -1 != s && (n = s));
            for (var s = [], q = 0, w = 0; w < n; w++) if (w % 4) {
                var v = p.indexOf(d.charAt(w - 1)) << 2 * (w % 4),
                    b = p.indexOf(d.charAt(w)) >>> 6 - 2 * (w % 4);
                s[q >>> 2] |= (v | b) << 24 - 8 * (q % 4);
                q++
            }
            return l.create(s, q)
        },
        _map: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="
    }
})();
(function(u) {
    function l(b, e, a, c, m, f, t) {
        b = b + (e & a | ~e & c) + m + t;
        return (b << f | b >>> 32 - f) + e
    }

    function d(b, e, a, c, m, f, t) {
        b = b + (e & c | a & ~c) + m + t;
        return (b << f | b >>> 32 - f) + e
    }

    function n(b, e, a, c, m, f, t) {
        b = b + (e ^ a ^ c) + m + t;
        return (b << f | b >>> 32 - f) + e
    }

    function p(b, e, a, c, m, f, t) {
        b = b + (a ^ (e | ~c)) + m + t;
        return (b << f | b >>> 32 - f) + e
    }
    for (var s = CryptoJS, q = s.lib, w = q.WordArray, v = q.Hasher, q = s.algo, b = [], x = 0; 64 > x; x++) b[x] = 4294967296 * u.abs(u.sin(x + 1)) | 0;
    q = q.MD5 = v.extend({
        _doReset: function() {
            this._hash = new w.init([1732584193, 4023233417, 2562383102, 271733878])
        },
        _doProcessBlock: function(r, e) {
            for (var a = 0; 16 > a; a++) {
                var c = e + a,
                    m = r[c];
                r[c] = (m << 8 | m >>> 24) & 16711935 | (m << 24 | m >>> 8) & 4278255360
            }
            var a = this._hash.words,
                c = r[e + 0],
                m = r[e + 1],
                f = r[e + 2],
                t = r[e + 3],
                y = r[e + 4],
                q = r[e + 5],
                s = r[e + 6],
                w = r[e + 7],
                v = r[e + 8],
                u = r[e + 9],
                x = r[e + 10],
                z = r[e + 11],
                A = r[e + 12],
                B = r[e + 13],
                C = r[e + 14],
                D = r[e + 15],
                g = a[0],
                h = a[1],
                j = a[2],
                k = a[3],
                g = l(g, h, j, k, c, 7, b[0]),
                k = l(k, g, h, j, m, 12, b[1]),
                j = l(j, k, g, h, f, 17, b[2]),
                h = l(h, j, k, g, t, 22, b[3]),
                g = l(g, h, j, k, y, 7, b[4]),
                k = l(k, g, h, j, q, 12, b[5]),
                j = l(j, k, g, h, s, 17, b[6]),
                h = l(h, j, k, g, w, 22, b[7]),
                g = l(g, h, j, k, v, 7, b[8]),
                k = l(k, g, h, j, u, 12, b[9]),
                j = l(j, k, g, h, x, 17, b[10]),
                h = l(h, j, k, g, z, 22, b[11]),
                g = l(g, h, j, k, A, 7, b[12]),
                k = l(k, g, h, j, B, 12, b[13]),
                j = l(j, k, g, h, C, 17, b[14]),
                h = l(h, j, k, g, D, 22, b[15]),
                g = d(g, h, j, k, m, 5, b[16]),
                k = d(k, g, h, j, s, 9, b[17]),
                j = d(j, k, g, h, z, 14, b[18]),
                h = d(h, j, k, g, c, 20, b[19]),
                g = d(g, h, j, k, q, 5, b[20]),
                k = d(k, g, h, j, x, 9, b[21]),
                j = d(j, k, g, h, D, 14, b[22]),
                h = d(h, j, k, g, y, 20, b[23]),
                g = d(g, h, j, k, u, 5, b[24]),
                k = d(k, g, h, j, C, 9, b[25]),
                j = d(j, k, g, h, t, 14, b[26]),
                h = d(h, j, k, g, v, 20, b[27]),
                g = d(g, h, j, k, B, 5, b[28]),
                k = d(k, g, h, j, f, 9, b[29]),
                j = d(j, k, g, h, w, 14, b[30]),
                h = d(h, j, k, g, A, 20, b[31]),
                g = n(g, h, j, k, q, 4, b[32]),
                k = n(k, g, h, j, v, 11, b[33]),
                j = n(j, k, g, h, z, 16, b[34]),
                h = n(h, j, k, g, C, 23, b[35]),
                g = n(g, h, j, k, m, 4, b[36]),
                k = n(k, g, h, j, y, 11, b[37]),
                j = n(j, k, g, h, w, 16, b[38]),
                h = n(h, j, k, g, x, 23, b[39]),
                g = n(g, h, j, k, B, 4, b[40]),
                k = n(k, g, h, j, c, 11, b[41]),
                j = n(j, k, g, h, t, 16, b[42]),
                h = n(h, j, k, g, s, 23, b[43]),
                g = n(g, h, j, k, u, 4, b[44]),
                k = n(k, g, h, j, A, 11, b[45]),
                j = n(j, k, g, h, D, 16, b[46]),
                h = n(h, j, k, g, f, 23, b[47]),
                g = p(g, h, j, k, c, 6, b[48]),
                k = p(k, g, h, j, w, 10, b[49]),
                j = p(j, k, g, h, C, 15, b[50]),
                h = p(h, j, k, g, q, 21, b[51]),
                g = p(g, h, j, k, A, 6, b[52]),
                k = p(k, g, h, j, t, 10, b[53]),
                j = p(j, k, g, h, x, 15, b[54]),
                h = p(h, j, k, g, m, 21, b[55]),
                g = p(g, h, j, k, v, 6, b[56]),
                k = p(k, g, h, j, D, 10, b[57]),
                j = p(j, k, g, h, s, 15, b[58]),
                h = p(h, j, k, g, B, 21, b[59]),
                g = p(g, h, j, k, y, 6, b[60]),
                k = p(k, g, h, j, z, 10, b[61]),
                j = p(j, k, g, h, f, 15, b[62]),
                h = p(h, j, k, g, u, 21, b[63]);
            a[0] = a[0] + g | 0;
            a[1] = a[1] + h | 0;
            a[2] = a[2] + j | 0;
            a[3] = a[3] + k | 0
        },
        _doFinalize: function() {
            var b = this._data,
                e = b.words,
                a = 8 * this._nDataBytes,
                c = 8 * b.sigBytes;
            e[c >>> 5] |= 128 << 24 - c % 32;
            var m = u.floor(a / 4294967296);
            e[(c + 64 >>> 9 << 4) + 15] = (m << 8 | m >>> 24) & 16711935 | (m << 24 | m >>> 8) & 4278255360;
            e[(c + 64 >>> 9 << 4) + 14] = (a << 8 | a >>> 24) & 16711935 | (a << 24 | a >>> 8) & 4278255360;
            b.sigBytes = 4 * (e.length + 1);
            this._process();
            b = this._hash;
            e = b.words;
            for (a = 0; 4 > a; a++) c = e[a], e[a] = (c << 8 | c >>> 24) & 16711935 | (c << 24 | c >>> 8) & 4278255360;
            return b
        },
        clone: function() {
            var b = v.clone.call(this);
            b._hash = this._hash.clone();
            return b
        }
    });
    s.MD5 = v._createHelper(q);
    s.HmacMD5 = v._createHmacHelper(q)
})(Math);
(function() {
    var u = CryptoJS,
        l = u.lib,
        d = l.Base,
        n = l.WordArray,
        l = u.algo,
        p = l.EvpKDF = d.extend({
            cfg: d.extend({
                keySize: 4,
                hasher: l.MD5,
                iterations: 1
            }),
            init: function(d) {
                this.cfg = this.cfg.extend(d)
            },
            compute: function(d, l) {
                for (var p = this.cfg, v = p.hasher.create(), b = n.create(), u = b.words, r = p.keySize, p = p.iterations; u.length < r;) {
                    e && v.update(e);
                    var e = v.update(d).finalize(l);
                    v.reset();
                    for (var a = 1; a < p; a++) e = v.finalize(e), v.reset();
                    b.concat(e)
                }
                b.sigBytes = 4 * r;
                return b
            }
        });
    u.EvpKDF = function(d, l, n) {
        return p.create(n).compute(d, l)
    }
})();
CryptoJS.lib.Cipher || function(u) {
    var l = CryptoJS,
        d = l.lib,
        n = d.Base,
        p = d.WordArray,
        s = d.BufferedBlockAlgorithm,
        q = l.enc.Base64,
        w = l.algo.EvpKDF,
        v = d.Cipher = s.extend({
            cfg: n.extend(),
            createEncryptor: function(m, a) {
                return this.create(this._ENC_XFORM_MODE, m, a)
            },
            createDecryptor: function(m, a) {
                return this.create(this._DEC_XFORM_MODE, m, a)
            },
            init: function(m, a, b) {
                this.cfg = this.cfg.extend(b);
                this._xformMode = m;
                this._key = a;
                this.reset()
            },
            reset: function() {
                s.reset.call(this);
                this._doReset()
            },
            process: function(a) {
                this._append(a);
                return this._process()
            },
            finalize: function(a) {
                a && this._append(a);
                return this._doFinalize()
            },
            keySize: 4,
            ivSize: 4,
            _ENC_XFORM_MODE: 1,
            _DEC_XFORM_MODE: 2,
            _createHelper: function(m) {
                return {
                    encrypt: function(f, b, e) {
                        return ("string" == typeof b ? c : a).encrypt(m, f, b, e)
                    },
                    decrypt: function(f, b, e) {
                        return ("string" == typeof b ? c : a).decrypt(m, f, b, e)
                    }
                }
            }
        });
    d.StreamCipher = v.extend({
        _doFinalize: function() {
            return this._process(!0)
        },
        blockSize: 1
    });
    var b = l.mode = {}, x = function(a, f, b) {
        var c = this._iv;
        c ? this._iv = u : c = this._prevBlock;
        for (var e = 0; e < b; e++) a[f + e] ^= c[e]
    }, r = (d.BlockCipherMode = n.extend({
        createEncryptor: function(a, f) {
            return this.Encryptor.create(a, f)
        },
        createDecryptor: function(a, f) {
            return this.Decryptor.create(a, f)
        },
        init: function(a, f) {
            this._cipher = a;
            this._iv = f
        }
    })).extend();
    r.Encryptor = r.extend({
        processBlock: function(a, f) {
            var b = this._cipher,
                c = b.blockSize;
            x.call(this, a, f, c);
            b.encryptBlock(a, f);
            this._prevBlock = a.slice(f, f + c)
        }
    });
    r.Decryptor = r.extend({
        processBlock: function(a, b) {
            var c = this._cipher,
                e = c.blockSize,
                d = a.slice(b, b + e);
            c.decryptBlock(a, b);
            x.call(this, a, b, e);
            this._prevBlock = d
        }
    });
    b = b.CBC = r;
    r = (l.pad = {}).Pkcs7 = {
        pad: function(a, b) {
            for (var c = 4 * b, c = c - a.sigBytes % c, e = c << 24 | c << 16 | c << 8 | c, d = [], l = 0; l < c; l += 4) d.push(e);
            c = p.create(d, c);
            a.concat(c)
        },
        unpad: function(a) {
            a.sigBytes -= a.words[a.sigBytes - 1 >>> 2] & 255
        }
    };
    d.BlockCipher = v.extend({
        cfg: v.cfg.extend({
            mode: b,
            padding: r
        }),
        reset: function() {
            v.reset.call(this);
            var a = this.cfg,
                c = a.iv,
                a = a.mode;
            if (this._xformMode == this._ENC_XFORM_MODE) var b = a.createEncryptor;
            else b = a.createDecryptor, this._minBufferSize = 1;
            this._mode = b.call(a, this, c && c.words)
        },
        _doProcessBlock: function(a, c) {
            this._mode.processBlock(a, c)
        },
        _doFinalize: function() {
            var a = this.cfg.padding;
            if (this._xformMode == this._ENC_XFORM_MODE) {
                a.pad(this._data, this.blockSize);
                var c = this._process(!0)
            } else c = this._process(!0), a.unpad(c);
            return c
        },
        blockSize: 4
    });
    var e = d.CipherParams = n.extend({
        init: function(a) {
            this.mixIn(a)
        },
        toString: function(a) {
            return (a || this.formatter).stringify(this)
        }
    }),
        b = (l.format = {}).OpenSSL = {
            stringify: function(a) {
                var c = a.ciphertext;
                a = a.salt;
                return (a ? p.create([1398893684, 1701076831]).concat(a).concat(c) : c).toString(q)
            },
            parse: function(a) {
                a = q.parse(a);
                var c = a.words;
                if (1398893684 == c[0] && 1701076831 == c[1]) {
                    var b = p.create(c.slice(2, 4));
                    c.splice(0, 4);
                    a.sigBytes -= 16
                }
                return e.create({
                    ciphertext: a,
                    salt: b
                })
            }
        }, a = d.SerializableCipher = n.extend({
            cfg: n.extend({
                format: b
            }),
            encrypt: function(a, c, b, d) {
                d = this.cfg.extend(d);
                var l = a.createEncryptor(b, d);
                c = l.finalize(c);
                l = l.cfg;
                return e.create({
                    ciphertext: c,
                    key: b,
                    iv: l.iv,
                    algorithm: a,
                    mode: l.mode,
                    padding: l.padding,
                    blockSize: a.blockSize,
                    formatter: d.format
                })
            },
            decrypt: function(a, c, b, e) {
                e = this.cfg.extend(e);
                c = this._parse(c, e.format);
                return a.createDecryptor(b, e).finalize(c.ciphertext)
            },
            _parse: function(a, c) {
                return "string" == typeof a ? c.parse(a, this) : a
            }
        }),
        l = (l.kdf = {}).OpenSSL = {
            execute: function(a, c, b, d) {
                d || (d = p.random(8));
                a = w.create({
                    keySize: c + b
                }).compute(a, d);
                b = p.create(a.words.slice(c), 4 * b);
                a.sigBytes = 4 * c;
                return e.create({
                    key: a,
                    iv: b,
                    salt: d
                })
            }
        }, c = d.PasswordBasedCipher = a.extend({
            cfg: a.cfg.extend({
                kdf: l
            }),
            encrypt: function(c, b, e, d) {
                d = this.cfg.extend(d);
                e = d.kdf.execute(e, c.keySize, c.ivSize);
                d.iv = e.iv;
                c = a.encrypt.call(this, c, b, e.key, d);
                c.mixIn(e);
                return c
            },
            decrypt: function(c, b, e, d) {
                d = this.cfg.extend(d);
                b = this._parse(b, d.format);
                e = d.kdf.execute(e, c.keySize, c.ivSize, b.salt);
                d.iv = e.iv;
                return a.decrypt.call(this, c, b, e.key, d)
            }
        })
}();
(function() {
    function u(b, a) {
        var c = (this._lBlock >>> b ^ this._rBlock) & a;
        this._rBlock ^= c;
        this._lBlock ^= c << b
    }

    function l(b, a) {
        var c = (this._rBlock >>> b ^ this._lBlock) & a;
        this._lBlock ^= c;
        this._rBlock ^= c << b
    }
    var d = CryptoJS,
        n = d.lib,
        p = n.WordArray,
        n = n.BlockCipher,
        s = d.algo,
        q = [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],
        w = [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],
        v = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28],
        b = [{
            "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
        }],
        x = [4160749569, 528482304, 33030144, 2064384, 129024, 8064, 504, 2147483679],
        r = s.DES = n.extend({
            _doReset: function() {
                for (var b = this._key.words, a = [], c = 0; 56 > c; c++) {
                    var d = q[c] - 1;
                    a[c] = b[d >>> 5] >>> 31 - d % 32 & 1
                }
                b = this._subKeys = [];
                for (d = 0; 16 > d; d++) {
                    for (var f = b[d] = [], l = v[d], c = 0; 24 > c; c++) f[c / 6 | 0] |= a[(w[c] - 1 + l) % 28] << 31 - c % 6, f[4 + (c / 6 | 0)] |= a[28 + (w[c + 24] - 1 + l) % 28] << 31 - c % 6;
                    f[0] = f[0] << 1 | f[0] >>> 31;
                    for (c = 1; 7 > c; c++) f[c] >>>= 4 * (c - 1) + 3;
                    f[7] = f[7] << 5 | f[7] >>> 27
                }
                a = this._invSubKeys = [];
                for (c = 0; 16 > c; c++) a[c] = b[15 - c]
            },
            encryptBlock: function(b, a) {
                this._doCryptBlock(b, a, this._subKeys)
            },
            decryptBlock: function(b, a) {
                this._doCryptBlock(b, a, this._invSubKeys)
            },
            _doCryptBlock: function(e, a, c) {
                this._lBlock = e[a];
                this._rBlock = e[a + 1];
                u.call(this, 4, 252645135);
                u.call(this, 16, 65535);
                l.call(this, 2, 858993459);
                l.call(this, 8, 16711935);
                u.call(this, 1, 1431655765);
                for (var d = 0; 16 > d; d++) {
                    for (var f = c[d], n = this._lBlock, p = this._rBlock, q = 0, r = 0; 8 > r; r++) q |= b[r][((p ^ f[r]) & x[r]) >>> 0];
                    this._lBlock = p;
                    this._rBlock = n ^ q
                }
                c = this._lBlock;
                this._lBlock = this._rBlock;
                this._rBlock = c;
                u.call(this, 1, 1431655765);
                l.call(this, 8, 16711935);
                l.call(this, 2, 858993459);
                u.call(this, 16, 65535);
                u.call(this, 4, 252645135);
                e[a] = this._lBlock;
                e[a + 1] = this._rBlock
            },
            keySize: 2,
            ivSize: 2,
            blockSize: 2
        });
    d.DES = n._createHelper(r);
    s = s.TripleDES = n.extend({
        _doReset: function() {
            var b = this._key.words;
            this._des1 = r.createEncryptor(p.create(b.slice(0, 2)));
            this._des2 = r.createEncryptor(p.create(b.slice(2, 4)));
            this._des3 = r.createEncryptor(p.create(b.slice(4, 6)))
        },
        encryptBlock: function(b, a) {
            this._des1.encryptBlock(b, a);
            this._des2.decryptBlock(b, a);
            this._des3.encryptBlock(b, a)
        },
        decryptBlock: function(b, a) {
            this._des3.decryptBlock(b, a);
            this._des2.encryptBlock(b, a);
            this._des1.decryptBlock(b, a)
        },
        keySize: 6,
        ivSize: 2,
        blockSize: 2
    });
    d.TripleDES = n._createHelper(s)
})();

function encryptByDESModeCBC(c, a) {
    b = CryptoJS.enc.Utf8.parse("2KL89TM3");
    var d = CryptoJS.enc.Utf8.parse(c);
    e = CryptoJS.DES.encrypt(a, d, {
        iv: b,
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    });
    return e.ciphertext.toString(CryptoJS.enc.Base64);
}
CryptoJS.mode.ECB = (function() {
    var ECB = CryptoJS.lib.BlockCipherMode.extend();
    ECB.Encryptor = ECB.extend({
        processBlock: function(words, offset) {
            this._cipher.encryptBlock(words, offset);
        }
    });
    ECB.Decryptor = ECB.extend({
        processBlock: function(words, offset) {
            this._cipher.decryptBlock(words, offset);
        }
    });
    return ECB;
}());

function decryptByDESModeCBC(key, ciphertext2) {
    var keyHex = CryptoJS.enc.Utf8.parse(key);
    var a = "2KL89TM3",
        b = CryptoJS.enc.Utf8.parse(a);
    var decrypted = CryptoJS.DES.decrypt({
        ciphertext: CryptoJS.enc.Base64.parse(ciphertext2)
    }, keyHex, {
        iv: b,
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    });
    return decrypted.toString(CryptoJS.enc.Utf8);
}



补充内容 (2024-5-20 18:29):
提取的软件内的JS
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表