【python 逆向分析惠农网】分析惠农网的【headers】载荷签名,并实现获取公开数据,全程异步跟栈,仅供学习参考

文章日期:2025.1.24

使用工具:Python、Node.js

本章知识:分析惠农网的【headers】载荷签名,有点多,就不展示了

文章难度:中等(比较麻烦,异步较多)

文章全程已做去敏处理!!!  【需要做的可联系我】 

AES解密处理(直接解密即可)(crypto-js.js 标准算法):​​​​​​在线AES加解密工具

仅供学习!仅供学习!仅供学习!

声明:本文逆向的所有内容文件仅供学习,从网站扣的代码不会公开,但博主自己写的代码内容将会公开在文章最底部,望谅解!!!

真男人不废话,先看效果图

1、打开某某网站(使用文章开头的AES在线工具解密):

afmN7ge3cm8Jebf+PNTG0KBXzhXl04jj6mY9v5Tzrh8DAg+qQAO0MvgEi+Plv6VQ

2、打开页面后,顺便打开控制台,然后我们随便翻一页,点开图中的【list】接口,仔细看一下 headers 载荷的内容,我们今天就把这几个参数分析一遍

3、我们全局搜索一下,然后进去看看

4、进来后直接把这些需要的代码转移到本地,我们先把这些生成规则模拟出现,最后再去找sign的生成规则

5、我把这几个参数的生成都直接做好了,也没什么特别的,我就不展示过程了,直接展示代码原理。这几个小参数过于简单,主要讲解sign的生成,这几个小参数大家看看就能懂,也可以自己尝试去扣下代码

6、接下来看一下找一下SIGN参数,直接在启动器里打断点,这里我就不展示了。断住后我们在堆栈里找一下,看哪里会是加密位置,根据分析,是在这个地方进行了异步加密,我们直接打上断点,跟栈看看

7、跟进来后,经过多次跟栈研究,发现他的SIGN是在这里生成的,我们继续跟进去

8、跟进了后,直接把代码全部扣走,然后模拟测试一下 

9、我把参数都一并复制过来了,运行后发现缺少L函数,我们直接去网站看看

10、我在网站上看了一下,发现他用来三元表达式,都是写死的固定参数。一眼看出是标准的SHA256算法

 11、下面的几个也一样,我们直接模拟即可,一眼懂,这三元表达式也不算太乱

12、 都补上后,再次运行发现缺少d参数,我测试后发现是缺少fromString函数方法,这个Node是没有这个方法的,直接去扣,我已经扣过了,也没难度,缺少这个方法的,直接去扣即可

13、补上后,再次运行发现下面有一个方法,这个其实也是标准的算法,SHA384算法

14、代码写好后,直接运行,看看还差什么,废话不多说,看动图,整个代码都进行展示

15、我们将JS代码进行整理,提供接口支持,然后用python进行读取接口加密信息,并请求公开数据,实现自动化。

【附上代码】请用Base64解密,即可得到源代码,如果使用不了,可能已经过时,网站进行了更新

注意~~仅供学习参考

【sign生成.js】请用Base64解密

const CryptoJS = require('crypto-js')
const express = require('express');

const app = express();
app.use(express.json());
function SHA256(text){
    return CryptoJS.SHA256(text).toString()
}
function SHA384(text){
    return CryptoJS.SHA384(text).toString()
}
function MD5(text){
    return CryptoJS.MD5(text).toString()
}
function SHA1(text){
    return CryptoJS.SHA1(text).toString()
}
X_CLIENT_ID = function(e) {
    var t = (new Date).getTime();
    return (e ? "xxxxxxxxxxxxxyxxxxyxxxxxxxxxxxxx" : "xxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxx").replace(/[xy]/g, (function(e) {
        var n = (t + 16 * Math.random()) % 16 | 0;
        return t = Math.floor(t / 16),
        ("x" == e ? n : 3 & n | 8).toString(16)
    }
    ))
}
X_CLIENT_SID  = function() {
    var r = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    function toBase36(e) {
        for (var t = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 9, b = e, n = ""; 0 != b; ) {
            var o = b % 36
              , l = b / 36;
            n = r.charAt(o) + n,
            b = Math.round(Math.floor(l))
        }
        return ("0000000000000000" + n).substr(-t)
    }

    var f = new Date
      , d = toBase36(f.getTime(), 9)
      , h = toBase36(Math.floor('2' + Math.random().toString().slice(-10)), 7)
    v = "S_" + d + h;
    return v;
}
X_B3_TRACEID = function(t) {
    var r = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    function toBase36(e) {
        for (var t = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 9, b = e, n = ""; 0 != b; ) {
            var o = b % 36
              , l = b / 36;
            n = r.charAt(o) + n,
            b = Math.round(Math.floor(l))
        }
        return ("0000000000000000" + n).substr(-t)
    }
    return toBase36(t, 9) + toBase36(Math.floor('2' + Math.random().toString().slice(-10)), 7)
}
X_CLIENT_NONCE = function() {
    return X_CLIENT_ID(true)

}

function ddddd(t, e) {
    var n = null;
    try {
        n = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11])),{}).exports
    } catch (t) {}
    function r(t, e, n) {
        this.low = 0 | t,
        this.high = 0 | e,
        this.unsigned = !!n
    }
    function o(t) {
        return !0 === (t && t.__isLong__)
    }
    r.prototype.__isLong__,
    Object.defineProperty(r.prototype, "__isLong__", {
        value: !0
    }),
    r.isLong = o;
    var l = {}
      , c = {};
    function h(t, e) {
        var n, r, o;
        return e ? (o = 0 <= (t >>>= 0) && t < 256) && (r = c[t]) ? r : (n = f(t, (0 | t) < 0 ? -1 : 0, !0),
        o && (c[t] = n),
        n) : (o = -128 <= (t |= 0) && t < 128) && (r = l[t]) ? r : (n = f(t, t < 0 ? -1 : 0, !1),
        o && (l[t] = n),
        n)
    }
    function d(t, e) {
        if (isNaN(t))
            return e ? k : C;
        if (e) {
            if (t < 0)
                return k;
            if (t >= w)
                return A
        } else {
            if (t <= -x)
                return I;
            if (t + 1 >= x)
                return O
        }
        return t < 0 ? d(-t, e).neg() : f(t % _ | 0, t / _ | 0, e)
    }
    function f(t, e, n) {
        return new r(t,e,n)
    }
    r.fromInt = h,
    r.fromNumber = d,
    r.fromBits = f;
    var m = Math.pow;
    function v(t, e, n) {
        if (0 === t.length)
            throw Error("empty string");
        if ("NaN" === t || "Infinity" === t || "+Infinity" === t || "-Infinity" === t)
            return C;
        if ("number" == typeof e ? (n = e,
        e = !1) : e = !!e,
        (n = n || 10) < 2 || 36 < n)
            throw RangeError("radix");
        var p;
        if ((p = t.indexOf("-")) > 0)
            throw Error("interior hyphen");
        if (0 === p)
            return v(t.substring(1), e, n).neg();
        for (var r = d(m(n, 8)), o = C, i = 0; i < t.length; i += 8) {
            var l = Math.min(8, t.length - i)
              , c = parseInt(t.substring(i, i + l), n);
            if (l < 8) {
                var h = d(m(n, l));
                o = o.mul(h).add(d(c))
            } else
                o = (o = o.mul(r)).add(d(c))
        }
        return o.unsigned = e,
        o
    }
    function y(t, e) {
        return "number" == typeof t ? d(t, e) : "string" == typeof t ? v(t, e) : f(t.low, t.high, "boolean" == typeof e ? e : t.unsigned)
    }
    r.fromString = v,
    r.fromValue = y;
    var _ = 4294967296
      , w = _ * _
      , x = w / 2
      , S = h(1 << 24)
      , C = h(0);
    r.ZERO = C;
    var k = h(0, !0);
    r.UZERO = k;
    var M = h(1);
    r.ONE = M;
    var E = h(1, !0);
    r.UONE = E;
    var T = h(-1);
    r.NEG_ONE = T;
    var O = f(-1, 2147483647, !1);
    r.MAX_VALUE = O;
    var A = f(-1, -1, !0);
    r.MAX_UNSIGNED_VALUE = A;
    var I = f(0, -2147483648, !1);
    r.MIN_VALUE = I;
    var L = r.prototype;
    L.toInt = function() {
        return this.unsigned ? this.low >>> 0 : this.low
    }
    ,
    L.toNumber = function() {
        return this.unsigned ? (this.high >>> 0) * _ + (this.low >>> 0) : this.high * _ + (this.low >>> 0)
    }
    ,
    L.toString = function(t) {
        if ((t = t || 10) < 2 || 36 < t)
            throw RangeError("radix");
        if (this.isZero())
            return "0";
        if (this.isNegative()) {
            if (this.eq(I)) {
                var e = d(t)
                  , div = this.div(e)
                  , n = div.mul(e).sub(this);
                return div.toString(t) + n.toInt().toString(t)
            }
            return "-" + this.neg().toString(t)
        }
        for (var r = d(m(t, 6), this.unsigned), o = this, l = ""; ; ) {
            var c = o.div(r)
              , h = (o.sub(c.mul(r)).toInt() >>> 0).toString(t);
            if ((o = c).isZero())
                return h + l;
            for (; h.length < 6; )
                h = "0" + h;
            l = "" + h + l
        }
    }
    ,
    L.getHighBits = function() {
        return this.high
    }
    ,
    L.getHighBitsUnsigned = function() {
        return this.high >>> 0
    }
    ,
    L.getLowBits = function() {
        return this.low
    }
    ,
    L.getLowBitsUnsigned = function() {
        return this.low >>> 0
    }
    ,
    L.getNumBitsAbs = function() {
        if (this.isNegative())
            return this.eq(I) ? 64 : this.neg().getNumBitsAbs();
        for (var t = 0 != this.high ? this.high : this.low, e = 31; e > 0 && 0 == (t & 1 << e); e--)
            ;
        return 0 != this.high ? e + 33 : e + 1
    }
    ,
    L.isZero = function() {
        return 0 === this.high && 0 === this.low
    }
    ,
    L.eqz = L.isZero,
    L.isNegative = function() {
        return !this.unsigned && this.high < 0
    }
    ,
    L.isPositive = function() {
        return this.unsigned || this.high >= 0
    }
    ,
    L.isOdd = function() {
        return 1 == (1 & this.low)
    }
    ,
    L.isEven = function() {
        return 0 == (1 & this.low)
    }
    ,
    L.equals = function(t) {
        return o(t) || (t = y(t)),
        (this.unsigned === t.unsigned || this.high >>> 31 != 1 || t.high >>> 31 != 1) && (this.high === t.high && this.low === t.low)
    }
    ,
    L.eq = L.equals,
    L.notEquals = function(t) {
        return !this.eq(t)
    }
    ,
    L.neq = L.notEquals,
    L.ne = L.notEquals,
    L.lessThan = function(t) {
        return this.comp(t) < 0
    }
    ,
    L.lt = L.lessThan,
    L.lessThanOrEqual = function(t) {
        return this.comp(t) <= 0
    }
    ,
    L.lte = L.lessThanOrEqual,
    L.le = L.lessThanOrEqual,
    L.greaterThan = function(t) {
        return this.comp(t) > 0
    }
    ,
    L.gt = L.greaterThan,
    L.greaterThanOrEqual = function(t) {
        return this.comp(t) >= 0
    }
    ,
    L.gte = L.greaterThanOrEqual,
    L.ge = L.greaterThanOrEqual,
    L.compare = function(t) {
        if (o(t) || (t = y(t)),
        this.eq(t))
            return 0;
        var e = this.isNegative()
          , n = t.isNegative();
        return e && !n ? -1 : !e && n ? 1 : this.unsigned ? t.high >>> 0 > this.high >>> 0 || t.high === this.high && t.low >>> 0 > this.low >>> 0 ? -1 : 1 : this.sub(t).isNegative() ? -1 : 1
    }
    ,
    L.comp = L.compare,
    L.negate = function() {
        return !this.unsigned && this.eq(I) ? I : this.not().add(M)
    }
    ,
    L.neg = L.negate,
    L.add = function(t) {
        o(t) || (t = y(t));
        var e = this.high >>> 16
          , n = 65535 & this.high
          , r = this.low >>> 16
          , l = 65535 & this.low
          , c = t.high >>> 16
          , h = 65535 & t.high
          , d = t.low >>> 16
          , m = 0
          , v = 0
          , _ = 0
          , w = 0;
        return _ += (w += l + (65535 & t.low)) >>> 16,
        v += (_ += r + d) >>> 16,
        m += (v += n + h) >>> 16,
        m += e + c,
        f((_ &= 65535) << 16 | (w &= 65535), (m &= 65535) << 16 | (v &= 65535), this.unsigned)
    }
    ,
    L.subtract = function(t) {
        return o(t) || (t = y(t)),
        this.add(t.neg())
    }
    ,
    L.sub = L.subtract,
    L.multiply = function(t) {
        if (this.isZero())
            return C;
        if (o(t) || (t = y(t)),
        n)
            return f(n.mul(this.low, this.high, t.low, t.high), n.get_high(), this.unsigned);
        if (t.isZero())
            return C;
        if (this.eq(I))
            return t.isOdd() ? I : C;
        if (t.eq(I))
            return this.isOdd() ? I : C;
        if (this.isNegative())
            return t.isNegative() ? this.neg().mul(t.neg()) : this.neg().mul(t).neg();
        if (t.isNegative())
            return this.mul(t.neg()).neg();
        if (this.lt(S) && t.lt(S))
            return d(this.toNumber() * t.toNumber(), this.unsigned);
        var e = this.high >>> 16
          , r = 65535 & this.high
          , l = this.low >>> 16
          , c = 65535 & this.low
          , h = t.high >>> 16
          , m = 65535 & t.high
          , v = t.low >>> 16
          , _ = 65535 & t.low
          , w = 0
          , x = 0
          , k = 0
          , M = 0;
        return k += (M += c * _) >>> 16,
        x += (k += l * _) >>> 16,
        k &= 65535,
        x += (k += c * v) >>> 16,
        w += (x += r * _) >>> 16,
        x &= 65535,
        w += (x += l * v) >>> 16,
        x &= 65535,
        w += (x += c * m) >>> 16,
        w += e * _ + r * v + l * m + c * h,
        f((k &= 65535) << 16 | (M &= 65535), (w &= 65535) << 16 | (x &= 65535), this.unsigned)
    }
    ,
    L.mul = L.multiply,
    L.divide = function(t) {
        if (o(t) || (t = y(t)),
        t.isZero())
            throw Error("division by zero");
        var e, r, l;
        if (n)
            return this.unsigned || -2147483648 !== this.high || -1 !== t.low || -1 !== t.high ? f((this.unsigned ? n.div_u : n.div_s)(this.low, this.high, t.low, t.high), n.get_high(), this.unsigned) : this;
        if (this.isZero())
            return this.unsigned ? k : C;
        if (this.unsigned) {
            if (t.unsigned || (t = t.toUnsigned()),
            t.gt(this))
                return k;
            if (t.gt(this.shru(1)))
                return E;
            l = k
        } else {
            if (this.eq(I))
                return t.eq(M) || t.eq(T) ? I : t.eq(I) ? M : (e = this.shr(1).div(t).shl(1)).eq(C) ? t.isNegative() ? M : T : (r = this.sub(t.mul(e)),
                l = e.add(r.div(t)));
            if (t.eq(I))
                return this.unsigned ? k : C;
            if (this.isNegative())
                return t.isNegative() ? this.neg().div(t.neg()) : this.neg().div(t).neg();
            if (t.isNegative())
                return this.div(t.neg()).neg();
            l = C
        }
        for (r = this; r.gte(t); ) {
            e = Math.max(1, Math.floor(r.toNumber() / t.toNumber()));
            for (var c = Math.ceil(Math.log(e) / Math.LN2), h = c <= 48 ? 1 : m(2, c - 48), v = d(e), _ = v.mul(t); _.isNegative() || _.gt(r); )
                _ = (v = d(e -= h, this.unsigned)).mul(t);
            v.isZero() && (v = M),
            l = l.add(v),
            r = r.sub(_)
        }
        return l
    }
    ,
    L.div = L.divide,
    L.modulo = function(t) {
        return o(t) || (t = y(t)),
        n ? f((this.unsigned ? n.rem_u : n.rem_s)(this.low, this.high, t.low, t.high), n.get_high(), this.unsigned) : this.sub(this.div(t).mul(t))
    }
    ,
    L.mod = L.modulo,
    L.rem = L.modulo,
    L.not = function() {
        return f(~this.low, ~this.high, this.unsigned)
    }
    ,
    L.and = function(t) {
        return o(t) || (t = y(t)),
        f(this.low & t.low, this.high & t.high, this.unsigned)
    }
    ,
    L.or = function(t) {
        return o(t) || (t = y(t)),
        f(this.low | t.low, this.high | t.high, this.unsigned)
    }
    ,
    L.xor = function(t) {
        return o(t) || (t = y(t)),
        f(this.low ^ t.low, this.high ^ t.high, this.unsigned)
    }
    ,
    L.shiftLeft = function(t) {
        return o(t) && (t = t.toInt()),
        0 == (t &= 63) ? this : t < 32 ? f(this.low << t, this.high << t | this.low >>> 32 - t, this.unsigned) : f(0, this.low << t - 32, this.unsigned)
    }
    ,
    L.shl = L.shiftLeft,
    L.shiftRight = function(t) {
        return o(t) && (t = t.toInt()),
        0 == (t &= 63) ? this : t < 32 ? f(this.low >>> t | this.high << 32 - t, this.high >> t, this.unsigned) : f(this.high >> t - 32, this.high >= 0 ? 0 : -1, this.unsigned)
    }
    ,
    L.shr = L.shiftRight,
    L.shiftRightUnsigned = function(t) {
        if (o(t) && (t = t.toInt()),
        0 === (t &= 63))
            return this;
        var e = this.high;
        return t < 32 ? f(this.low >>> t | e << 32 - t, e >>> t, this.unsigned) : f(32 === t ? e : e >>> t - 32, 0, this.unsigned)
    }
    ,
    L.shru = L.shiftRightUnsigned,
    L.shr_u = L.shiftRightUnsigned,
    L.toSigned = function() {
        return this.unsigned ? f(this.low, this.high, !1) : this
    }
    ,
    L.toUnsigned = function() {
        return this.unsigned ? this : f(this.low, this.high, !0)
    }
    ,
    L.toBytes = function(t) {
        return t ? this.toBytesLE() : this.toBytesBE()
    }
    ,
    L.toBytesLE = function() {
        var t = this.high
          , e = this.low;
        return [255 & e, e >>> 8 & 255, e >>> 16 & 255, e >>> 24, 255 & t, t >>> 8 & 255, t >>> 16 & 255, t >>> 24]
    }
    ,
    L.toBytesBE = function() {
        var t = this.high
          , e = this.low;
        return [t >>> 24, t >>> 16 & 255, t >>> 8 & 255, 255 & t, e >>> 24, e >>> 16 & 255, e >>> 8 & 255, 255 & e]
    }
    ,
    r.fromBytes = function(t, e, n) {
        return n ? r.fromBytesLE(t, e) : r.fromBytesBE(t, e)
    }
    ,
    r.fromBytesLE = function(t, e) {
        return new r(t[0] | t[1] << 8 | t[2] << 16 | t[3] << 24,t[4] | t[5] << 8 | t[6] << 16 | t[7] << 24,e)
    }
    ,
    r.fromBytesBE = function(t, e) {
        return new r(t[4] << 24 | t[5] << 16 | t[6] << 8 | t[7],t[0] << 24 | t[1] << 16 | t[2] << 8 | t[3],e)
    }
    return r
}
SIGN = function(e,head) {
    var t, n, f = ["w4jDq38=", "ST7CoA==", "GGDChQ==", "YQ1u", "azJe", "w4jClzc=", "wqrDpCM=", "woUiw5E=", "w6jDlUc=", "wovDrgI=", "FMKcfQ==", "wonCuMKH", "w5NwHQ==", "w4jCiWY=", "wrcHMw==", "w7kLQA==", "Z8OiwqU=", "IsKcwpk=", "IcKYIQ==", "w7Vzw5c=", "wqAbw4Q=", "djYB", "R8KzwpY=", "w5fDssKG", "fxpw", "wq8owrI=", "ZcKuwpw=", "wq4ewqo=", "wo5ow4E=", "Wmc/", "w7TDgCQ=", "woHDo8OY", "wo3DpcKT", "PnVd", "wqkcRw==", "w7PDm8KB", "wqtTXg==", "wpjDrSw=", "wokkPw==", "w550w6o=", "fDlM", "QMO7wrU=", "EmzDlA==", "PzrDkg==", "wpVzHA==", "w5UTwr4=", "wq4DwpA=", "woptdg==", "w7XDt8Km", "w7wHw5w=", "woMMw7w=", "wpoUGQ==", "AGNe", "AXfDrw==", "w6vDqi0=", "w7Rcw4U=", "SWA3", "wpzClTI=", "wrAoEw==", "w6XDkMKq", "wrEkJQ==", "wqLDnS8=", "w7I2w7o=", "BWzDqQ==", "w41ANg==", "w4JQw5I=", "wrPDglM=", "wofDscO/", "w5EZw60=", "wpxuwo8=", "c3Rl", "w4jCig0=", "wot8eg==", "wpjDu8Kw", "MUvDrw==", "MsKPIw==", "wow2BA==", "J8KawpA=", "X8O7wpo=", "LGlG", "LmVX", "wonCpcK9", "EsKaQA==", "woXDg8Oj", "FMKQdw==", "w55TRA==", "M8KYJw==", "dMKkw54=", "w6IJw6k=", "wpDCkmA=", "CsKQfQ==", "w7DDgxY=", "ZsKbQw==", "Cll6", "w55HQg==", "wrBLMg==", "wrB+MQ==", "wqtPw6M=", "w7nCtw0=", "w4pZGg==", "wpVwQg==", "HVRE", "wrzDtik=", "w6lOYQ==", "PGNj", "a3Rt", "wrgtw7o=", "VcOPHw=="];
    t = f,
    n = 130,
    function(e) {
        for (; --e; )
            t.push(t.shift())
    }(++n);
    var h, v, y, m, x, _, w, C, S, M, O, W, k, P, V, R, E, j, D, F, A, $, T, I, H = function e(t, n) {
        var r, o = f[t -= 0];
        if (void 0 === e.LXLBwO) {
            (r = function() {
                var e = void 0;
                try {
                    e = Function('return (function() {}.constructor("return this")( ));')()
                } catch (t) {
                    e = window
                }
                return e
            }()).atob || (r.atob = function(e) {
                for (var t, n, r = String(e).replace(/=+$/, ""), o = "", l = 0, c = 0; n = r.charAt(c++); ~n && (t = l % 4 ? 64 * t + n : n,
                l++ % 4) ? o += String.fromCharCode(255 & t >> (-2 * l & 6)) : 0)
                    n = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".indexOf(n);
                return o
            }
            );
            e.wgSwSe = function(e, t) {
                for (var n = [], r = 0, o = void 0, l = "", c = "", f = 0, d = (e = atob(e)).length; f < d; f++)
                    c += "%" + ("00" + e.charCodeAt(f).toString(16)).slice(-2);
                e = decodeURIComponent(c);
                var h = void 0;
                for (h = 0; h < 256; h++)
                    n[h] = h;
                for (h = 0; h < 256; h++)
                    r = (r + n[h] + t.charCodeAt(h % t.length)) % 256,
                    o = n[h],
                    n[h] = n[r],
                    n[r] = o;
                h = 0,
                r = 0;
                for (var v = 0; v < e.length; v++)
                    r = (r + n[h = (h + 1) % 256]) % 256,
                    o = n[h],
                    n[h] = n[r],
                    n[r] = o,
                    l += String.fromCharCode(e.charCodeAt(v) ^ n[(n[h] + n[r]) % 256]);
                return l
            }
            ,
            e.oiZDRX = {},
            e.LXLBwO = !0
        }
        var l = e.oiZDRX[t];
        return void 0 === l ? (void 0 === e.pGfKGq && (e.pGfKGq = !0),
        o = e.wgSwSe(o, n),
        e.oiZDRX[t] = o) : o = l,
        o
    }, K = e[H("0x29", "3MMx") + H("0x67", "]hVA")][H("0x5a", "Ph1Y")] === H("0x39", "wXa9"), L = K ? "WYbq0N" + H("0x20", "up@!") + H("0x50", "GEhp") + H("0x66", "voet") + H("0x5e", "up@!") + H("0x6a", "&J@X") + H("0x51", "2w[1") + H("0x5d", "h2!t") + "NJtQC" : H("0x9", "xaTo") + H("0xb", "wXa9") + H("0x3d", "xaTo") + H("0x5c", "up@!") + H("0x4", "##Ru") + H("0x47", "wXa9") + "h5&" + H("0x33", "Ugh5") + H("0x23", "3HK4") + H("0x58", "gI!u") + "#V", G = K ? "xX1sgJ" + H("0x64", ")3bD") + "v9bQOe" + H("0x4d", "q1C$") + "0Ie3kK" + H("0x4f", "wXa9") + H("0x2", "Ph1Y") + "JT" : H("0x4c", "aq3T") + H("0x59", "9GkD") + H("0x2e", "h2!t") + H("0x34", "3MMx") + H("0x13", "voet") + H("0xd", "xaTo") + H("0x35", "%M3Q") + H("0x15", "3MMx") + H("0x21", "&J@X") + "gnAcr", N = K ? H("0x27", "Z$b]") + H("0x2c", "GEhp") + H("0x56", "CQ]W") + H("0x10", "8dp[") + H("0xe", "J7to") + "r5O1TL" + H("0x2f", "g0vo") + "ZpK" + H("0x2d", "UV[o") + "Kd" : H("0x1c", "J1wu") + H("0x3", "&J@X") + H("0x57", "&IEu") + "ljl" + H("0xa", "DlUD") + "WYk" + H("0x54", "Cbz8") + H("0x0", "##Ru") + "2Rn" + H("0x1", "eBRZ") + "hR", B = "pc" === e[H("0x37", "]hVA") + H("0x3a", "wXa9")][H("0x45", "up@!") + H("0x3f", "HJjC") + "rm"], Q = {
        nonce: head[H("0x63", "CQ]W") + H("0x30", "9GkD") + H("0x49", "J7to") + "NONCE"],
        timestamp: String(head[H("0x28", "g0vo") + "LIE" + H("0x49", "J7to") + H("0x53", "9GkD") + "E"]),
        deviceId: head["X-C" + H("0x6", "@ycV") + "NT-ID"],
        secret: e[H("0x42", "&J@X") + "v"][H("0x2b", "jOT4") + "pp"] ? L : B ? N : G,
        secretType: e[H("0xc", "2w[1") + "v"][H("0x1a", "eBRZ") + "pp"] ? 1 : B ? 3 : 2
    };
    return Q[H("0x62", "q1C$") + "ce"] && Q[H("0x7", "zwd1") + "est" + H("0x43", "!sAd")] && Q[H("0x36", "8dp[") + H("0x1e", "HtSW") + "Id"] && (head[H("0x4a", "8dp[") + "LIE" + H("0x49", "J7to") + H("0xf", "Z$b]") + "N"] = (V = (h = Q).nonce,
    R = h.timestamp,
    E = h.deviceId,
    j = h.secret,
    D = h.secretType,
    v = V,
    F = SHA256(v),
    m = R,
    A = SHA384(m),
    _ = E,
    w = V,
    $ = MD5(w + (H("0x16", "q1C$") + H("0x1d", ")3bD") + "l)") + _),
    S = j,
    M = R,
    W = "",
    W = SHA1(M + (H("0x69", "g0vo") + H("0x17", "J1wu") + H("0x41", "voet") + H("0x46", "9Ynf") + H("0x2a", "J7to")) + S),
    W = W[H("0x5f", "GEhp") + "str" + H("0x4b", "@ycV")](W[H("0x44", "oChJ") + H("0x25", "azqg")] - 16, W[H("0x55", "9Ynf") + H("0x1f", "3MMx")] - 1),
    T = ddddd().fromString(W, !0, 16)['toUnsigned']()['toString'](10),
    P = [F, A, $, T],
    I = 1 === (k = D) ? P[H("0x12", "Ph1Y") + H("0x32", "J7to")]((function(e, t) {
        return e + "" + t
    }
    )) : 2 === k ? P[H("0x3e", "oChJ") + H("0x24", ")3bD")]((function(e, t) {
        return e + "!" + t
    }
    )) : 3 === k ? P.reduce((function(e, t) {
        return e + (H("0x4e", "q1C$") + "o)") + t
    }
    )) : void 0)),
    SHA384(I)
}

e = {}
e.$env = {
    "inDesktop": true,
    "inBrowser": true,
    "inWeex": false,
    "inApp": false,
    "inAppIOS": false,
    "inAppAndroid": false,
    "weexPlatform": false,
    "UA": "mozilla/5.0 (windows nt 10.0; win64; x64) applewebkit/537.36 (khtml, like gecko) chrome/130.0.0.0 safari/537.36",
    "isIE": false,
    "isIE9": false,
    "isEdge": false,
    "isAndroid": false,
    "isIOS": false,
    "isChrome": true,
    "isPhantomJS": false,
    "barHeight": 90
}
e.config = {
    "peach": "",
    "monk": "https://gateway.cnhnb.com/monk",
    "banana": "https://gateway.cnhnb.com/banana",
    "qiniu": {
        "privateUrl": "",
        "upLoadUrl": "http://upload-z2.qiniup.com",
        "downLoadUrl": ""
    },
    "fontEnd": "https://m.cnhnb.com",
    "mobile": "https://mobile.cnhnb.com",
    "merchant": "https://merchant.cnhnb.com",
    "news": "https://news.cnhnb.com",
    "m": "https://m.cnhnb.com",
    "pc": "https://www.cnhnb.com",
    "env": "pro",
    "imgUrl": "https://image.cnhnb.com/",
    "pigsy": "https://pcapi.cnhnb.com",
    "platform": "pc",
    "AppID": 4,
    "zst": "https://zst.cnhnb.com",
    "$defaultConfig": {
        "httpConfig": {
            "method": "POST",
            "isToastError": true,
            "headers": {
                "osType": "wap",
                "content-type": "application/json"
            }
        }
    }
}

// 检测服务是否已打开
app.get('/', (req, res) => {
    // 13位时间戳
    TIME = new Date().getTime()
    // 生成请求头信息
    head = {
        "X-CLIENT-APPID": '4',
        "X-B3-TRACEID": X_B3_TRACEID(TIME),
        "X-CLIENT-TIME": TIME,
        "X-CLIENT-PAGE": "",
        "X-HN-JOB": "If you see these message, I hope you dont hack us, I hope you can join us! Please visit https://www.cnhnkj.com/job.html",
        "X-CLIENT-NONCE": X_CLIENT_NONCE(),
        "X-CLIENT-ENVIRONMENT": "pro",
        "X-CLIENT-ID": X_CLIENT_ID(),
        "X-CLIENT-SID": X_CLIENT_SID()
    }
    datajson = {
        ...head,
        'X-CLIENT-SIGN':SIGN(e,head)    // 生成签名 sign
    }
    console.log('生成结果 ->',datajson)
    res.status(200).json(datajson);
});



app.listen(4000, () => {
    console.log('Node.js 服务监听端口 127.0.0.1:4000');
});

【关键字提取.py】请用Base64解密

aW1wb3J0IGpzb24KaW1wb3J0IHJlcXVlc3RzCgpjbGFzcyBjbmhuYjoKICAgIGRlZiBfX2luaXRfXyhzZWxmKToKICAgICAgICAjIOiOt+WPliBoZWFkZXJzIHRva2Vu5Luk54mMCiAgICAgICAgc2VsZi5oZWFkZXJzX3Rva2VuX2RhdGEgPSBzZWxmLmhlYWRlcnNfdG9rZW4oKQogICAgICAgIHNlbGYucmVzcG9uc2VfZGF0YSgpCgogICAgIyDojrflj5YgaGVhZGVycyB0b2tlbuS7pOeJjAogICAgZGVmIGhlYWRlcnNfdG9rZW4oc2VsZikgLT4gZGljdDoKICAgICAgICAjIOivt+axguacrOWcsOeahGpz5o6l5Y+jCiAgICAgICAgaGVhZGVyc190b2tlbl9kYXRhID0gcmVxdWVzdHMuZ2V0KCJodHRwOi8vMTI3LjAuMC4xOjQwMDAvIikuanNvbigpCiAgICAgICAgcHJpbnQoJ2hlYWRlcnMgdG9rZW7ku6TniYznlJ/miJDnu5PmnpzvvJonLCBoZWFkZXJzX3Rva2VuX2RhdGEpCiAgICAgICAgcmV0dXJuIGhlYWRlcnNfdG9rZW5fZGF0YQoKICAgICMg6K+35rGC5pWw5o2uCiAgICBkZWYgcmVzcG9uc2VfZGF0YShzZWxmKToKICAgICAgICAjIOazqOaEj++8muS4gOWumuimgeazqOaEjyBoZWFkZXJzIOmHjOeahOmUrueahOWkp+Wwj+WGme+8jOWmguaenOWkp+Wwj+WGmeaciemXrumimO+8jOS5n+S8muWvvOiHtOivt+axguWHuueOsOmUmeivr++8jOW7uuiuruS9v+eUqOaKk+WMhei9r+S7tui/m+ihjOaPkOWPlu+8jOaIluebtOaOpeS9v+eUqOaIkeWGmeWlveeahCBoZWFkZXJzCiAgICAgICAgaGVhZGVycyA9IHsKICAgICAgICAgICAgIkNvbm5lY3Rpb24iOiAia2VlcC1hbGl2ZSIsCiAgICAgICAgICAgICJDb250ZW50LUxlbmd0aCI6ICIxNSIsCiAgICAgICAgICAgICJQcmFnbWEiOiAibm8tY2FjaGUiLAogICAgICAgICAgICAiQ2FjaGUtQ29udHJvbCI6ICJuby1jYWNoZSIsCiAgICAgICAgICAgICJzZWMtY2gtdWEtcGxhdGZvcm0iOiAiXCJXaW5kb3dzXCIiLAogICAgICAgICAgICAic2VjLWNoLXVhIjogJyJDaHJvbWl1bSI7dj0iMTMwIiwgIkJyYXZlIjt2PSIxMzAiLCAiTm90P0FfQnJhbmQiO3Y9Ijk5IicsCiAgICAgICAgICAgICJzZWMtY2gtdWEtbW9iaWxlIjogIj8wIiwKICAgICAgICAgICAgIkFjY2VwdCI6ICJhcHBsaWNhdGlvbi9qc29uLCB0ZXh0L3BsYWluLCAqLyoiLAogICAgICAgICAgICAiWC1DTElFTlQtQVBQSUQiOiAiNCIsCiAgICAgICAgICAgICJDb250ZW50LVR5cGUiOiAiYXBwbGljYXRpb24vanNvbiIsCiAgICAgICAgICAgICJTZWMtRmV0Y2gtU2l0ZSI6ICJzYW1lLXNpdGUiLAogICAgICAgICAgICAiU2VjLUZldGNoLU1vZGUiOiAiY29ycyIsCiAgICAgICAgICAgICJTZWMtRmV0Y2gtRGVzdCI6ICJlbXB0eSIsCiAgICAgICAgICAgICJBY2NlcHQtRW5jb2RpbmciOiAiZ3ppcCwgZGVmbGF0ZSwgYnIsIHpzdGQiLAogICAgICAgICAgICAiQWNjZXB0LUxhbmd1YWdlIjogInpoLUNOLHpoO3E9MC45IiwKICAgICAgICAgICAgIlNlYy1HUEMiOiAiMSIsCiAgICAgICAgICAgICJVc2VyLUFnZW50IjogIk1vemlsbGEvNS4wIChXaW5kb3dzIE5UIDEwLjA7IFdpbjY0OyB4NjQpIEFwcGxlV2ViS2l0LzUzNy4zNiAoS0hUTUwsIGxpa2UgR2Vja28pIENocm9tZS8xMzAuMC4wLjAgU2FmYXJpLzUzNy4zNiIsCiAgICAgICAgICAgICJYLUIzLVRSQUNFSUQiOiBzZWxmLmhlYWRlcnNfdG9rZW5fZGF0YVsiWC1CMy1UUkFDRUlEIl0sICAgICMgVFJBQ0VJRCDov5nkuKpUUkFDRUlE5piv5qC55o2uIOOAkOWFs+mUruaXtumXtOaIs+OAkSvjgJDpmo/mnLrlgLznlJ/miJDnmoTjgJHvvIjmlbDlrZcr5aSn5YaZ5a2X5q+N57uE5oiQ77yJIDE25L2N6ZW/5bqmCiAgICAgICAgICAgICJYLUNMSUVOVC1FTlZJUk9OTUVOVCI6ICJwcm8iLAogICAgICAgICAgICAiWC1DTElFTlQtSUQiOiBzZWxmLmhlYWRlcnNfdG9rZW5fZGF0YVsiWC1DTElFTlQtSUQiXSwgICAgICAgIyBVVUlECiAgICAgICAgICAgICJYLUNMSUVOVC1OT05DRSI6IHNlbGYuaGVhZGVyc190b2tlbl9kYXRhWyJYLUNMSUVOVC1OT05DRSJdLCAgICMgVVVJRCDlj6rmmK/ljrvmjonkuobjgJAt44CR56ym5Y+36ICM5beyCiAgICAgICAgICAgICJYLUNMSUVOVC1QQUdFIjogIi9wLy8iLCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAjIOayoeS7gOS5iOeUqO+8jOWPr+S7pei3s+i/h++8jOS9huS4jeiDveS4uuepugogICAgICAgICAgICAiWC1DTElFTlQtU0lEIjogc2VsZi5oZWFkZXJzX3Rva2VuX2RhdGFbIlgtQ0xJRU5ULVNJRCJdLCAgICAjIFNJRCAg6L+Z5LiqU0lE5piv5qC55o2u55Sf5oiQU0lE55qE5pe26Ze05oiz6ICM55Sf5oiQ55qE44CQMuS9jeWbuuWumuWAvCvmlbDlrZcr5aSn5YaZ5a2X5q+NIOmaj+acuueUn+aIkOOAkSAgMTjkvY3plb/luqYKICAgICAgICAgICAgIlgtQ0xJRU5ULVNJR04iOiBzZWxmLmhlYWRlcnNfdG9rZW5fZGF0YVsiWC1DTElFTlQtU0lHTiJdLCAgICAgIyBzaWduIOetvuWQjSAgOTbkvY3plb/luqYgIOmHh+eUqOWkmuenjeWTiOW4jOeul+azlSBTSEEyNTYvU0hBMzg0L01ENS9TSEExCiAgICAgICAgICAgICJYLUNMSUVOVC1USU1FIjogZiJ7c2VsZi5oZWFkZXJzX3Rva2VuX2RhdGFbJ1gtQ0xJRU5ULVRJTUUnXX0iLCAgICAgICAgICAgICAgICMg5YWz6ZSu5pe26Ze05oizICAxM+S9jemVv+W6pgogICAgICAgICAgICAiWC1ITi1KT0IiOiAiSWYgeW91IHNlZSB0aGVzZSBtZXNzYWdlLCBJIGhvcGUgeW91IGRvbnQgaGFjayB1cywgSSBob3BlIHlvdSBjYW4gam9pbiB1cyEgUGxlYXNlIHZpc2l0IGh0dHBzOi8vd3d3LmNuaG5rai5jb20vam9iLmh0bWwiICAgICMg5q2k5Y+C5pWw5Li65Zu65a6a5Y+C5pWwIOS5n+WPr+S7peS9nOS4uumYsueIrOiZq+eahOWPguaVsOS5i+S4gO+8jOWboOS4uui/meS4quWPguaVsOWPr+S7peWvuemDqOWIhue9keermSBjdXJsIHRvIFB5dGhvbiDlgZrlh7rpmLLmiqTvvIjlpJrms6jmhI/kuIDkuIvljbPlj6/vvInjgIIKICAgICAgICB9CgogICAgICAgIHVybCA9ICJodHRwczovL3BjYXBpLmNuaG5iLmNvbS9lc2VhcmNoLXBjL2FwaS90cmFuc2Zvcm0vc3VwcGx5L2xpc3QiCiAgICAgICAgZGF0YSA9IHsKICAgICAgICAgICAgInNvcnRPcmRlciI6ICJkZXNjIiwKICAgICAgICAgICAgInBhZ2VOdW1iZXIiOiAyLCAgIyDnrKzlh6DpobUKICAgICAgICAgICAgInBhZ2VTaXplIjogMTAwLCAgIyDmr4/pobXojrflj5blpJrlsJHmnaHmlbDmja4g5a6Y572R6buY6K6kMjAKICAgICAgICAgICAgImtleXdvcmQiOiAi6Iu55p6cIiAgIyDlhbPplK7lrZcKICAgICAgICB9CgogICAgICAgIGRhdGEgPSBqc29uLmR1bXBzKGRhdGEsIHNlcGFyYXRvcnM9KCcsJywgJzonKSkKICAgICAgICByZXNwb25zZSA9IHJlcXVlc3RzLnBvc3QodXJsLCBoZWFkZXJzPWhlYWRlcnMsIGRhdGE9ZGF0YSkKCiAgICAgICAgcHJpbnQocmVzcG9uc2UudGV4dCkKICAgICAgICBwcmludChyZXNwb25zZSkKCmNuaG5iKCkKCg==

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/961310.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[论文阅读] (37)CCS21 DeepAID:基于深度学习的异常检测(解释)

祝大家新春快乐,蛇年吉祥! 《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座,并分享给大家,希望您喜欢。由于作者的英文水平和学术能力不高,需要不断提升,所以还请大家批评指正&#xff0…

使用Avalonia UI实现DataGrid

1.Avalonia中的DataGrid的使用 DataGrid 是客户端 UI 中一个非常重要的控件。在 Avalonia 中,DataGrid 是一个独立的包 Avalonia.Controls.DataGrid,因此需要单独通过 NuGet 安装。接下来,将介绍如何安装和使用 DataGrid 控件。 2.安装 Dat…

DeepSeek-R1:开源Top推理模型的实现细节、使用与复现

核心观点 ● 直接用强化学习就可以让模型获得显著的推理能力,说明并不一定需要SFT才行。 ● 强化学习并不一定需要复杂的奖励模型,使用简单的规则反而取得意想不到的效果。 ● 通过知识蒸馏让小模型一定程度上也有推理能力,甚至在某些场景下…

Linux 阻塞IO

Linux 阻塞IO 阻塞IO是最常见的IO,我们使用的 scanf()、cin 等都是阻塞IO。

Ubuntu 安装 QGIS LTR 3.34

QGIS官方提供了安装指南:https://qgis.org/resources/installation-guide/#linux。大多数linux发行版将QGIS拆分为几个包:qgis、qgis-python、qgis-grass、qgis-plugin-grass、qgis-server,有的包最初安装时被跳过,可以在需要使用…

Spring Boot - 数据库集成05 - 集成MongoDB

Spring Boot集成MongoDB 文章目录 Spring Boot集成MongoDB一:使用前的准备1:依赖导入 & 配置2:实体类创建 二:核心 - MongoRepository三:核心 - MongoTemplate1:集合操作2:文档操作(重点)3&…

SpringCloud系列教程:微服务的未来(十八)雪崩问题、服务保护方案、Sentinel快速入门

前言 在分布式系统中,雪崩效应(Avalanche Effect)是一种常见的故障现象,通常发生在系统中某个组件出现故障时,导致其他组件级联失败,最终引发整个系统的崩溃。为了有效应对雪崩效应,服务保护方…

Golang Gin系列-7:认证和授权

在本章中,我们将探讨Gin框架中身份验证和授权的基本方面。这包括实现基本的和基于令牌的身份验证,使用基于角色的访问控制,应用中间件进行授权,以及使用HTTPS和漏洞防护保护应用程序。 实现身份认证 Basic 认证 Basic 认证是内置…

C++ 中用于控制输出格式的操纵符——setw 、setfill、setprecision、fixed

目录 四种操纵符简要介绍 setprecision基本用法 setfill的基本用法 fixed的基本用法 setw基本用法 以下是一些常见的用法和示例: 1. 设置字段宽度和填充字符 2. 设置字段宽度和对齐方式 3. 设置字段宽度和精度 4. 设置字段宽度和填充字符,结合…

06_改善播放效果--优先级与阻塞

一、声明 本文章的程序是基于05篇的程序改善的,所以CubeMx的配置看05篇的就好 且此篇文章由于红外遥控暂时未使用,还不知其是否能成功显示现象 二、keil5代码 这个优先级要1,但是如果只是这个优先级1的话,那么我的LED灯闪烁的任务…

【Rust自学】16.3. 共享状态的并发

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 16.3.1. 使用共享来实现并发 还记得Go语言有一句名言是这么说的:Do not commun…

项目集成Nacos

文章目录 1.环境搭建1.创建模块 sunrays-common-cloud-nacos-starter2.目录结构3.pom.xml4.自动配置1.NacosAutoConfiguration.java2.spring.factories 5.引入cloud模块通用依赖 2.测试1.创建模块 sunrays-common-cloud-nacos-starter-demo2.目录结构3.pom.xml4.application.ym…

计算机网络 (59)无线个人区域网WPAN

前言 无线个人区域网(WPAN,Wireless Personal Area Network)是一种以个人为中心,采用无线连接方式的个人局域网。 一、定义与特点 定义:WPAN是以个人为中心,实现活动半径小、业务类型丰富、面向特定群体的无…

Python 之 Excel 表格常用操作

示例文件 test.xlsx 将各个表单拆分成单独的 Excel 文件 import os.pathimport openpyxl import pandasdef handle_excel(file_path):dirname os.path.dirname(file_path)basename os.path.basename(file_path).split(".")[0]wb openpyxl.load_workbook(file_pat…

01学习预热篇(D6_正式踏入JVM深入学习前的铺垫)

目录 学习前言 一、虚拟机的结构 1. Java虚拟机参数设置 2. java 堆 3. 出入栈 4. 局部变量表 1> 局部变量的剖析 2> 局部变量的回收 5. 操作数栈 1> 常量入栈指令 2> 局部变量值转载到栈中指令 3> 将栈顶值保存到局部变量中指令 6. 帧数据区 7. 栈…

知识库建设对提升团队协作与创新能力的影响分析

内容概要 在当今快速变革的商业环境中,知识库建设的重要性愈发凸显。它不仅是信息存储的载体,更是推动组织内部沟通与协作的基石。通过系统整理与管理企业知识,团队成员能够便捷地访问相关信息,使得协作过程更为流畅,…

C语言字符串详解

1. C语言中的字符串基础 C语言中的字符串是程序设计中不可忽视的部分。与现代高级编程语言不同,C语言对字符串的处理方式直接、灵活,并且强大。在C语言中,字符串并不是一种特殊的数据类型,而是字符数组的一种表现形式。字符串通常…

神经网络的通俗介绍

人工神经网络,是一种模仿人类大脑工作原理的数学模型。人类的大脑是由无数的小“工作站”组成的,每个工作站叫做“神经元”。这些神经元通过“电线”互相连接,负责接收、处理和传递信息。 一、人类大脑神经网络 人类大脑的神经网络大概长这…

SpringBoot中Excel表的导入、导出功能的实现

文章目录 一、easyExcel简介二、Excel表的导出2.1 添加 Maven 依赖2.2 创建导出数据的实体类4. 编写导出接口5. 前端代码6. 实现效果 三、excel表的导出1. Excel表导入的整体流程1.1 配置文件存储路径 2. 前端实现2.1 文件上传组件 2.2 文件上传逻辑3. 后端实现3.1 文件上传接口…

vim交换文件的工作原理

在vim中,交换文件是一个临时文件,当我们使用vim打开一个文件进行编辑(一定得是做出了修改才会产生交换文件)时候,vim就会自动创建一个交换文件,而之后我们对于文件的一系列修改都是在交换文件中进行的&…