逆向案例二十八——红某点集登录接口逆向序

news2024/11/26 4:48:30

网址:aHR0cHM6Ly93d3cuaHJkanl1bi5jb20vIy9sb2dpbj9yZWRpcmVjdD0lMkZyZWFsVGltZUxpdmluZw==

登录接口,发现两个参数加密,分别是pwd和sig,t很明显是时间戳。

观察pwd,发现很像md5加密,我输入的密码是123456,在在线加密网站加密,发现果然如此。

但是这次采用扣代码来解决,不用标准库。

 

参数没有特点,搜索是很难搜的,采用跟栈方法。

 还是跟之前一样,点击第一个,在send处打断点,点击登录,前三个是发包,一般不在里面吗加密。

现在就是判断是不是在异步里面加密的,如何判断呢, 进入异步s.requests处,在常见位置打上断点。在控制台打印e,进入第一个函数在return处打上断点,看加密了吗?若是加密了,则并不是在异步中加密的。

 

发现进入异步的第一个函数接受的参数已经是经过加密的数据,因此跳过异步。 

 

进入下一个栈,G栈,在u处打上断点,释放其他断点,点击登录

看l = l = Object(g["a"])(H(S(e)))就是sig的加密位置,Object(g["a"])代码的意思就是调用g中的a方法。相当于g["a"](H(S(e)),但是这里存在变量污染,传入的参数s不应该含有加密后的sig,所以在前面打上断点,可以更好确定传入的参数是什么形式的。

 

在这里打上断定,var t = n.split("/") ,再点击跳过下一个函数执行,一步步执行到sig的加密位置。

这时候的传入的参数为e

 

t由s赋值,s由函数 s = (new Date).getTime();赋值

那么现在还是要先破解pwd是怎么加密的。

先找到pwd的加密位置。由于传入function G(n,e)中的e已经有加密后的pwd了,所以继续往前跟栈。

pwd由pwd: Object(E["a"])(t.loginForm.password)赋值,相当于E["a"](t.loginForm.password),其中t.loginForm.password是密码'123456'

 

进入E['a']发现是它,复制到pycharm中,传入的n就是密码,运行会发现缺少c,就在前面找c,然后复制

 

 

c在哪里,就在这个函数附近。然后运行发现没有o,接着复制一步一步来,最后直到成功。

 

完整代码:

var a=0;
function i(n) {
            return c(o(s(n)))
};
function c(n) {
            for (var e, t = a ? "0123456789ABCDEF" : "0123456789abcdef", i = "", o = 0; o < n.length; o++)
                e = n.charCodeAt(o),
                i += t.charAt(e >>> 4 & 15) + t.charAt(15 & e);
            return i
 };
function o(n) {
            return r(d(l(n), 8 * n.length))
        };
function s(n) {
            var e, t, a = "", i = -1;
            while (++i < n.length)
                e = n.charCodeAt(i),
                t = i + 1 < n.length ? n.charCodeAt(i + 1) : 0,
                55296 <= e && e <= 56319 && 56320 <= t && t <= 57343 && (e = 65536 + ((1023 & e) << 10) + (1023 & t),
                i++),
                e <= 127 ? a += String.fromCharCode(e) : e <= 2047 ? a += String.fromCharCode(192 | e >>> 6 & 31, 128 | 63 & e) : e <= 65535 ? a += String.fromCharCode(224 | e >>> 12 & 15, 128 | e >>> 6 & 63, 128 | 63 & e) : e <= 2097151 && (a += String.fromCharCode(240 | e >>> 18 & 7, 128 | e >>> 12 & 63, 128 | e >>> 6 & 63, 128 | 63 & e));
            return a
        };
function r(n) {
            for (var e = "", t = 0; t < 32 * n.length; t += 8)
                e += String.fromCharCode(n[t >> 5] >>> t % 32 & 255);
            return e
        };
function d(n, e) {
            n[e >> 5] |= 128 << e % 32,
            n[14 + (e + 64 >>> 9 << 4)] = e;
            for (var t = 1732584193, a = -271733879, i = -1732584194, o = 271733878, c = 0; c < n.length; c += 16) {
                var s = t
                  , l = a
                  , r = i
                  , d = o;
                t = h(t, a, i, o, n[c + 0], 7, -680876936),
                o = h(o, t, a, i, n[c + 1], 12, -389564586),
                i = h(i, o, t, a, n[c + 2], 17, 606105819),
                a = h(a, i, o, t, n[c + 3], 22, -1044525330),
                t = h(t, a, i, o, n[c + 4], 7, -176418897),
                o = h(o, t, a, i, n[c + 5], 12, 1200080426),
                i = h(i, o, t, a, n[c + 6], 17, -1473231341),
                a = h(a, i, o, t, n[c + 7], 22, -45705983),
                t = h(t, a, i, o, n[c + 8], 7, 1770035416),
                o = h(o, t, a, i, n[c + 9], 12, -1958414417),
                i = h(i, o, t, a, n[c + 10], 17, -42063),
                a = h(a, i, o, t, n[c + 11], 22, -1990404162),
                t = h(t, a, i, o, n[c + 12], 7, 1804603682),
                o = h(o, t, a, i, n[c + 13], 12, -40341101),
                i = h(i, o, t, a, n[c + 14], 17, -1502002290),
                a = h(a, i, o, t, n[c + 15], 22, 1236535329),
                t = m(t, a, i, o, n[c + 1], 5, -165796510),
                o = m(o, t, a, i, n[c + 6], 9, -1069501632),
                i = m(i, o, t, a, n[c + 11], 14, 643717713),
                a = m(a, i, o, t, n[c + 0], 20, -373897302),
                t = m(t, a, i, o, n[c + 5], 5, -701558691),
                o = m(o, t, a, i, n[c + 10], 9, 38016083),
                i = m(i, o, t, a, n[c + 15], 14, -660478335),
                a = m(a, i, o, t, n[c + 4], 20, -405537848),
                t = m(t, a, i, o, n[c + 9], 5, 568446438),
                o = m(o, t, a, i, n[c + 14], 9, -1019803690),
                i = m(i, o, t, a, n[c + 3], 14, -187363961),
                a = m(a, i, o, t, n[c + 8], 20, 1163531501),
                t = m(t, a, i, o, n[c + 13], 5, -1444681467),
                o = m(o, t, a, i, n[c + 2], 9, -51403784),
                i = m(i, o, t, a, n[c + 7], 14, 1735328473),
                a = m(a, i, o, t, n[c + 12], 20, -1926607734),
                t = A(t, a, i, o, n[c + 5], 4, -378558),
                o = A(o, t, a, i, n[c + 8], 11, -2022574463),
                i = A(i, o, t, a, n[c + 11], 16, 1839030562),
                a = A(a, i, o, t, n[c + 14], 23, -35309556),
                t = A(t, a, i, o, n[c + 1], 4, -1530992060),
                o = A(o, t, a, i, n[c + 4], 11, 1272893353),
                i = A(i, o, t, a, n[c + 7], 16, -155497632),
                a = A(a, i, o, t, n[c + 10], 23, -1094730640),
                t = A(t, a, i, o, n[c + 13], 4, 681279174),
                o = A(o, t, a, i, n[c + 0], 11, -358537222),
                i = A(i, o, t, a, n[c + 3], 16, -722521979),
                a = A(a, i, o, t, n[c + 6], 23, 76029189),
                t = A(t, a, i, o, n[c + 9], 4, -640364487),
                o = A(o, t, a, i, n[c + 12], 11, -421815835),
                i = A(i, o, t, a, n[c + 15], 16, 530742520),
                a = A(a, i, o, t, n[c + 2], 23, -995338651),
                t = p(t, a, i, o, n[c + 0], 6, -198630844),
                o = p(o, t, a, i, n[c + 7], 10, 1126891415),
                i = p(i, o, t, a, n[c + 14], 15, -1416354905),
                a = p(a, i, o, t, n[c + 5], 21, -57434055),
                t = p(t, a, i, o, n[c + 12], 6, 1700485571),
                o = p(o, t, a, i, n[c + 3], 10, -1894986606),
                i = p(i, o, t, a, n[c + 10], 15, -1051523),
                a = p(a, i, o, t, n[c + 1], 21, -2054922799),
                t = p(t, a, i, o, n[c + 8], 6, 1873313359),
                o = p(o, t, a, i, n[c + 15], 10, -30611744),
                i = p(i, o, t, a, n[c + 6], 15, -1560198380),
                a = p(a, i, o, t, n[c + 13], 21, 1309151649),
                t = p(t, a, i, o, n[c + 4], 6, -145523070),
                o = p(o, t, a, i, n[c + 11], 10, -1120210379),
                i = p(i, o, t, a, n[c + 2], 15, 718787259),
                a = p(a, i, o, t, n[c + 9], 21, -343485551),
                t = f(t, s),
                a = f(a, l),
                i = f(i, r),
                o = f(o, d)
            }
            return Array(t, a, i, o)
        };
function l(n) {
            for (var e = Array(n.length >> 2), t = 0; t < e.length; t++)
                e[t] = 0;
            for (t = 0; t < 8 * n.length; t += 8)
                e[t >> 5] |= (255 & n.charCodeAt(t / 8)) << t % 32;
            return e
        };
function h(n, e, t, a, i, o, c) {
            return u(e & t | ~e & a, n, e, i, o, c)
        };
function f(n, e) {
            var t = (65535 & n) + (65535 & e)
              , a = (n >> 16) + (e >> 16) + (t >> 16);
            return a << 16 | 65535 & t
        };
function g(n, e) {
            return n << e | n >>> 32 - e
        };
function m(n, e, t, a, i, o, c) {
            return u(e & a | t & ~a, n, e, i, o, c)
        };
function A(n, e, t, a, i, o, c) {
            return u(e ^ t ^ a, n, e, i, o, c)
        };
function p(n, e, t, a, i, o, c) {
            return u(t ^ (e | ~a), n, e, i, o, c)
        };


function u(n, e, t, a, i, o) {
            return f(g(f(f(e, n), f(a, o)), i), t)
        }


console.log(i('123456'))

运行结果

 

看复制的代码的位置,其实就是'87ff'中的绝大部分代码块,之所以不用webpack是因为'87ff'没有调用其他的模块,所以直接扣就可以。

 

现在处理sig怎么加密的,先生成e,跟上面的步骤一样来。

然后开始写 

 g["a"](H(S(e)),回到G栈,找到S函数,H函数,g['a']函数。并复制

它们分别为

 

 

g.a其实就是i函数。最后结果。

 

最终代码:

var a = 0;

function p(n, e, t, a, i, o, c) {
    return u(t ^ (e | ~a), n, e, i, o, c)
};

function A(n, e, t, a, i, o, c) {
    return u(e ^ t ^ a, n, e, i, o, c)
};

function m(n, e, t, a, i, o, c) {
    return u(e & a | t & ~a, n, e, i, o, c)
};

function g(n, e) {
    return n << e | n >>> 32 - e
};

function f(n, e) {
    var t = (65535 & n) + (65535 & e)
        , a = (n >> 16) + (e >> 16) + (t >> 16);
    return a << 16 | 65535 & t
};

function u(n, e, t, a, i, o) {
    return f(g(f(f(e, n), f(a, o)), i), t)
};

function h(n, e, t, a, i, o, c) {
    return u(e & t | ~e & a, n, e, i, o, c)
};

function l(n) {
    for (var e = Array(n.length >> 2), t = 0; t < e.length; t++)
        e[t] = 0;
    for (t = 0; t < 8 * n.length; t += 8)
        e[t >> 5] |= (255 & n.charCodeAt(t / 8)) << t % 32;
    return e
};

function d(n, e) {
    n[e >> 5] |= 128 << e % 32,
        n[14 + (e + 64 >>> 9 << 4)] = e;
    for (var t = 1732584193, a = -271733879, i = -1732584194, o = 271733878, c = 0; c < n.length; c += 16) {
        var s = t
            , l = a
            , r = i
            , d = o;
        t = h(t, a, i, o, n[c + 0], 7, -680876936),
            o = h(o, t, a, i, n[c + 1], 12, -389564586),
            i = h(i, o, t, a, n[c + 2], 17, 606105819),
            a = h(a, i, o, t, n[c + 3], 22, -1044525330),
            t = h(t, a, i, o, n[c + 4], 7, -176418897),
            o = h(o, t, a, i, n[c + 5], 12, 1200080426),
            i = h(i, o, t, a, n[c + 6], 17, -1473231341),
            a = h(a, i, o, t, n[c + 7], 22, -45705983),
            t = h(t, a, i, o, n[c + 8], 7, 1770035416),
            o = h(o, t, a, i, n[c + 9], 12, -1958414417),
            i = h(i, o, t, a, n[c + 10], 17, -42063),
            a = h(a, i, o, t, n[c + 11], 22, -1990404162),
            t = h(t, a, i, o, n[c + 12], 7, 1804603682),
            o = h(o, t, a, i, n[c + 13], 12, -40341101),
            i = h(i, o, t, a, n[c + 14], 17, -1502002290),
            a = h(a, i, o, t, n[c + 15], 22, 1236535329),
            t = m(t, a, i, o, n[c + 1], 5, -165796510),
            o = m(o, t, a, i, n[c + 6], 9, -1069501632),
            i = m(i, o, t, a, n[c + 11], 14, 643717713),
            a = m(a, i, o, t, n[c + 0], 20, -373897302),
            t = m(t, a, i, o, n[c + 5], 5, -701558691),
            o = m(o, t, a, i, n[c + 10], 9, 38016083),
            i = m(i, o, t, a, n[c + 15], 14, -660478335),
            a = m(a, i, o, t, n[c + 4], 20, -405537848),
            t = m(t, a, i, o, n[c + 9], 5, 568446438),
            o = m(o, t, a, i, n[c + 14], 9, -1019803690),
            i = m(i, o, t, a, n[c + 3], 14, -187363961),
            a = m(a, i, o, t, n[c + 8], 20, 1163531501),
            t = m(t, a, i, o, n[c + 13], 5, -1444681467),
            o = m(o, t, a, i, n[c + 2], 9, -51403784),
            i = m(i, o, t, a, n[c + 7], 14, 1735328473),
            a = m(a, i, o, t, n[c + 12], 20, -1926607734),
            t = A(t, a, i, o, n[c + 5], 4, -378558),
            o = A(o, t, a, i, n[c + 8], 11, -2022574463),
            i = A(i, o, t, a, n[c + 11], 16, 1839030562),
            a = A(a, i, o, t, n[c + 14], 23, -35309556),
            t = A(t, a, i, o, n[c + 1], 4, -1530992060),
            o = A(o, t, a, i, n[c + 4], 11, 1272893353),
            i = A(i, o, t, a, n[c + 7], 16, -155497632),
            a = A(a, i, o, t, n[c + 10], 23, -1094730640),
            t = A(t, a, i, o, n[c + 13], 4, 681279174),
            o = A(o, t, a, i, n[c + 0], 11, -358537222),
            i = A(i, o, t, a, n[c + 3], 16, -722521979),
            a = A(a, i, o, t, n[c + 6], 23, 76029189),
            t = A(t, a, i, o, n[c + 9], 4, -640364487),
            o = A(o, t, a, i, n[c + 12], 11, -421815835),
            i = A(i, o, t, a, n[c + 15], 16, 530742520),
            a = A(a, i, o, t, n[c + 2], 23, -995338651),
            t = p(t, a, i, o, n[c + 0], 6, -198630844),
            o = p(o, t, a, i, n[c + 7], 10, 1126891415),
            i = p(i, o, t, a, n[c + 14], 15, -1416354905),
            a = p(a, i, o, t, n[c + 5], 21, -57434055),
            t = p(t, a, i, o, n[c + 12], 6, 1700485571),
            o = p(o, t, a, i, n[c + 3], 10, -1894986606),
            i = p(i, o, t, a, n[c + 10], 15, -1051523),
            a = p(a, i, o, t, n[c + 1], 21, -2054922799),
            t = p(t, a, i, o, n[c + 8], 6, 1873313359),
            o = p(o, t, a, i, n[c + 15], 10, -30611744),
            i = p(i, o, t, a, n[c + 6], 15, -1560198380),
            a = p(a, i, o, t, n[c + 13], 21, 1309151649),
            t = p(t, a, i, o, n[c + 4], 6, -145523070),
            o = p(o, t, a, i, n[c + 11], 10, -1120210379),
            i = p(i, o, t, a, n[c + 2], 15, 718787259),
            a = p(a, i, o, t, n[c + 9], 21, -343485551),
            t = f(t, s),
            a = f(a, l),
            i = f(i, r),
            o = f(o, d)
    }
    return Array(t, a, i, o)
};

function r(n) {
    for (var e = "", t = 0; t < 32 * n.length; t += 8)
        e += String.fromCharCode(n[t >> 5] >>> t % 32 & 255);
    return e
};

function c(n) {
    for (var e, t = a ? "0123456789ABCDEF" : "0123456789abcdef", i = "", o = 0; o < n.length; o++)
        e = n.charCodeAt(o),
            i += t.charAt(e >>> 4 & 15) + t.charAt(15 & e);
    return i
};

function o(n) {
    return r(d(l(n), 8 * n.length))
};

function i(n) {
    return c(o(s(n)))
};

function s(n) {
    var e, t, a = "", i = -1;
    while (++i < n.length)
        e = n.charCodeAt(i),
            t = i + 1 < n.length ? n.charCodeAt(i + 1) : 0,
        55296 <= e && e <= 56319 && 56320 <= t && t <= 57343 && (e = 65536 + ((1023 & e) << 10) + (1023 & t),
            i++),
            e <= 127 ? a += String.fromCharCode(e) : e <= 2047 ? a += String.fromCharCode(192 | e >>> 6 & 31, 128 | 63 & e) : e <= 65535 ? a += String.fromCharCode(224 | e >>> 12 & 15, 128 | e >>> 6 & 63, 128 | 63 & e) : e <= 2097151 && (a += String.fromCharCode(240 | e >>> 18 & 7, 128 | e >>> 12 & 63, 128 | e >>> 6 & 63, 128 | 63 & e));
    return a
};

function H(n) {
    var e = []
        , t = "";
    for (var a in n)
        e.push(n[a]);
    for (var i = 0; i < e.length; i++)
        t += e[i] + "";
    return t += "JzyqgcoojMiQNuQoTlbR5EBT8TsqzJ",
        t
};

function S(n) {
    for (var e = Object.keys(n).sort(), t = {}, a = 0; a < e.length; a++)
        t[e[a]] = n[e[a]];
    return t
};

password = '123456'
phoneNum = "18720180853"
function get_info(phoneNum,password){
    pwd = i(password)
    e = {
        "phoneNum": phoneNum,
        "pwd": pwd,
        "t": (new Date).getTime(),
        "tenant": 1,
    }
    // console.log(i(password))
    sig = i(H(S(e)))
    return [pwd,sig,e.t]
}
console.log(get_info(phoneNum,password))

用python调用访问代码: 

import requests
import execjs
f = open('红人点集.js','r',encoding='utf-8').read()
json_code = execjs.compile(f)
data = json_code.call('get_info','18720180853','123456')
print(data)
headers = {
    'Accept': 'application/json, text/plain, */*',
    'Accept-Language': 'zh-CN,zh;q=0.9',
    'Cache-Control': 'no-cache',
    'Connection': 'keep-alive',
    'Content-Type': 'application/json',
    'Origin': 'https://www.hrdjyun.com',
    'Pragma': 'no-cache',
    'Sec-Fetch-Dest': 'empty',
    'Sec-Fetch-Mode': 'cors',
    'Sec-Fetch-Site': 'same-site',
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36',
    'sec-ch-ua': '"Not_A Brand";v="8", "Chromium";v="120", "Google Chrome";v="120"',
    'sec-ch-ua-mobile': '?0',
    'sec-ch-ua-platform': '"Windows"',
}

json_data = {
    'phoneNum': '18720180853',
    'pwd': data[0],
    't': data[2],
    'tenant': 1,
    'sig': data[1],
}

response = requests.post('https://user.hrdjyun.com/wechat/phonePwdLogin', headers=headers, json=json_data)
print(response.json())

 

 

 

 

 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

mac安装nvm详细教程

0. 前提 清除电脑上原有的node (没有装过的可以忽略)1、首先查看电脑上是否安装的有node,查看node版本node -v2、如果有node就彻底删除nodesudo rm -rf /usr/local/{bin/{node,npm},lib/node_modules/npm,lib/node,share/man/*/node.*}2、保证自己的电脑上有安装git,不然下载n…

Python基于Django的旅游城市关键词分析和提取,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

基于Java+SpringBoot+Mybaties-plus+Vue+elememt 小区物业管理系统 的设计与实现

一.项目介绍 系统分为管理员 和 业主 两块&#xff1a; 管理员点击进入到系统操作界面&#xff0c;可以对首页、业主信息管理、管理员信息管理、 楼栋和房屋信息管理、物业费管理、地下停车位管理、公告信息管理、报修信息管理、 投诉管理以及个人信息等功能模块 …

数字逻辑课程实验环境配置与使用说明

文章目录 I.虚拟机搭建1.1 Vmware安装1.2 Win XP安装1.3 xftp7安装 I. Quartus II安装II. 使用说明2.1 新建工程2.2 在工程中加入代码2.3 代码编译波形仿真 I.虚拟机搭建 1.1 Vmware安装 Vmware17安装教程 1.2 Win XP安装 Win XP安装教程 1.3 xftp7安装 给虚拟机添加FTP …

部署wordpress

查看别名type ll ll 是 ls -l --colorauto 的别名 设置别名alias alias ymyum install -y 使用别名ym nginx 取消别名unalias ym 基于LNMP做一个wordpress nginx mysql 5.7 PHP 7.4 1、linux基本环境 修改主机名 hostnamectl set-hostname $name 关闭防火墙及selinux …

python爬豆瓣top250电影

文章目录 前言分析与实现1.对豆瓣网网站进行Ajax分析2.发送请求3.进一步筛选&#xff08;提取&#xff09; 完整代码 前言 通过这个项目&#xff0c;可以让小白对爬虫有一个初步认识&#xff0c;爬取豆瓣top250是一个初学者学爬虫的必经之路&#xff0c;话不多说&#xff0c;我…

【缓存常见问题】

在使用缓存时特别是在高并发场景下会遇到很多问题&#xff0c;常用的问题有缓存穿透、缓存击穿、缓存雪崩以及缓存一致性问题。 1、缓存穿透 首先&#xff0c;什么是缓存穿透呢&#xff1f; 缓存穿透是指请求一个不存在的数据&#xff0c;缓存层和数据库层都没有这个数据&…

图片各种格式区别介绍:

图片各种格式区别介绍&#xff1a; JPEG格式&#xff08;Joint Photographic Experts Group&#xff09; JPEG格式一种有损压缩格式&#xff0c;能够将图像压缩在很小的储存空间&#xff0c;图像中重复或不重要的资料会被丢失&#xff0c;因此容易造成图像数据的损伤。尤其是…

目标检测——防护装备数据集

一、重要性及意义 防护装备中的头盔和背心检测具有至关重要的重要性和深远的意义&#xff0c;主要体现在以下几个方面&#xff1a; 首先&#xff0c;它们对于保护工作人员的人身安全起着至关重要的作用。在各类工作环境中&#xff0c;尤其是那些涉及高空作业、机械操作或交通…

Python教学入门:数字类型与字符串

数字类型&#xff08;Numeric Types&#xff09;&#xff1a; 整数&#xff08;int&#xff09;&#xff1a; 在 Python 中&#xff0c;整数是不可变的&#xff0c;可以表示正整数、负整数和零。 Python 中整数的大小仅受限于计算机的内存。 # 定义整数变量 num1 10 num2 -…

【Linux系统编程】第五弹---基本指令(三)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、grep指令 2、zip/unzip指令 3、tar指令 4、bc指令 5、uname指令 6、重要的几个热键 7、拓展指令 总结 1、grep指令 …

Pulsar【部署 01】消息队列PULSAR在Linux环境的主程序安装使用(小内存服务器问题处理)

官方网站&#xff1a;https://pulsar.apache.org/ 对于本地开发和测试&#xff0c;您可以在机器上以单机模式运行Pulsar。单机模式在单个Java虚拟机(JVM)进程中运行所有组件。本地单机版安装手册&#xff1a; 消息队列PULSAR在Linux环境的主程序安装使用 1.Prerequisites1.1 Pu…

四种算法(麻雀搜索算法SSA、螳螂搜索算法MSA、红尾鹰算法RTH、霸王龙优化算法TROA)求解机器人路径规划(提供MATLAB代码)

一、机器人路径规划介绍 移动机器人&#xff08;Mobile robot&#xff0c;MR&#xff09;的路径规划是 移动机器人研究的重要分支之&#xff0c;是对其进行控制的基础。根据环境信息的已知程度不同&#xff0c;路径规划分为基于环境信息已知的全局路径规划和基于环境信息未知或…

Flink KafkaSink分区配置的不同版本对比

Flink KafkaSink分区配置的不同版本对比 在不同版本的Flink中&#xff0c;KafkaSink 分区默认配置方式可能会有一些变化。以下是摘自Flink官方文档不同版本的原文&#xff1a; 1. Flink版本&#xff1a;1.12~1.19 Sink 分区 # 配置项 sink.partitioner 指定了从 Flink 分区到 …

12个可能未使用过的Python特性

大多数程序员不知道的令人难以置信的功能列表。 Python 是顶级编程语言之一&#xff0c;它具有许多程序员从未使用过的许多隐藏功能。在这篇文章中&#xff0c;我将分享你可能从未使用过的13 个 Python 特性。 1.列表Stepping 这是一个 step 参数&#xff0c;可以通过采取几…

六西格玛培训公司怎么选?一篇就够你明白

在如今六西格玛培训公司琳琅满目的市场中&#xff0c;如何挑选出一家既专业又符合自身需求的公司呢&#xff1f;本文将为大家提供一些实用的建议&#xff0c;助您在挑选六西格玛培训公司时不再迷茫。 一、明确培训目标 在选择六西格玛培训公司之前&#xff0c;首先要明确自己的…

nginx代理https地址报阿里云Web应用防火墙 (WAF)

项目中开通的网络策略都是从nginx代理出去&#xff0c;当代理的地址是阿里云地址时出现了如下错误。 我的nginx配置如下 在网上查资料发现&#xff0c;阿里是通过请求头中的host来校验域名是否存在来拦截该请求。最终配置如下&#xff1a; location /test/ { prox…

数据结构学习记录

数据结构 数组 & 链表 相连性 | 指向性 数组可以迅速定位到数组中某一个节点的位置 链表则需要通过前一个元素指向下一个元素&#xff0c;需要前后依赖顺序查找&#xff0c;效率较低 实现链表 // head > node1 > node2 > ... > nullclass Node {constructo…

C语言 | 动态内存管理

目录&#xff1a; 1. 为什么要有动态内存分配 2. malloc和free 3. calloc和realloc 4. 常见的动态内存的错误 5. 动态内存经典笔试题分析 6. 柔性数组 1. 为什么要有动态内存分配 我们已经掌握的内存开辟方式有&#xff1a; int val 20; //在栈空间上开辟四个字节 cha…

【笔试强训】Day1 --- 数字统计 + 两个数组的交集 + 点击消除

文章目录 1. 数字统计2. 两个数组的交集3. 点击消除 1. 数字统计 【链接】&#xff1a;数字统计 解题思路&#xff1a;模拟&#xff0c;利用数学知识&#xff0c;计算每个数字中2出现的个数。&#xff08;这里也可以将数字转换成字符串来统计字符’2’出现的个数&#xff09…