• x程无忧sign逆向分析


    x程无忧sign逆向分析:

    详情页sign:

    详情页网站:

    import base64
    # 解码
    result = base64.b64decode('aHR0cHM6Ly9qb2JzLjUxam9iLmNvbS9ndWFuZ3pob3UvMTUxODU1MTYyLmh0bWw/cz1zb3Vfc291X3NvdWxiJnQ9MF8wJnJlcT0zODQ4NGQxMzc2Zjc4MDY2M2Y1MGY2YTg0NmE1NmExMiZ0aW1lc3RhbXBfXzEyNTg9ZXFBeGNEUkNQbXFDcUdORFEwaFQzZEdPUURrREJHaFlEJmFsaWNobGdyZWY9aHR0cHMlM0ElMkYlMkZ3ZS41MWpvYi5jb20lMkY='.encode('utf-8'))
    print(result)
    
    • 1
    • 2
    • 3
    • 4

    我们会发现有两个接口,一个结果用于验证,一个接口用于返回信息。

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    ​ 大部分的网站不会在send和ajax进行参数的加密,只是作为请求发送.

    在这里插入图片描述

    ​ 有一点前端基础的同学们,可能发现很简单,就是调用jQuery根据id获取值,

    在这里插入图片描述

    我们多发几次请求会发现这个值不会变化。

    在这里插入图片描述

    观察这个js文件,感觉很像自调用函数,而且还有点想webpack.

    sign是一个对象,如下:

    在这里插入图片描述

    弄了半天,发现这个sign是写在document里面的,我们可以xpath,或者正则得到这个数据

    在这里插入图片描述

    当然也可以扣js但是需要补环境,我们后面的实例中会说到,本次就不涉及补环境了。

    导航目录页sign:

    在这里插入图片描述

    在这里插入图片描述

    我们选择XHR断点调试。

    在这里插入图片描述

    优先考虑异步回调栈

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    去掉前方端点和xhr端点,因为我们找到真正的位置了

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    // 引入CryptoJS库
    const CryptoJS = require("crypto-js");
    let text='123456';
    
    
    e='/api/job/search-pc?api_key=51job×tamp=1700060794&keyword=python%E5%B7%A5%E7%A8%8B%E5%B8%88&searchType=2&function=&industry=&jobArea=000000&jobArea2=&landmark=&metro=&salary=&workYear=°ree=&companyType=&companySize=&jobType=&issueDate=&sortType=0&pageNum=4&requestId=6213e8eec0a779cf85e0abe18d57ab62&pageSize=20&source=1&accountId=&pageCode=sou%7Csou%7Csoulb'
    sign_key="abfc8f9dcf8c3f3d8aa294ac5f2cf2cc7767e5592590f39c3f503271dd68562b"
    // 计算并且转化为16进制字符串
    let secret=CryptoJS.HmacSHA256(e,sign_key).toString(CryptoJS.enc.Hex);
    console.log(secret)
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    UUID的实现:

    在这里插入图片描述

  • 相关阅读:
    leetcode-67:二进制求和
    如何看待Unity新的收费模式?
    面试必备(背)--计算机网络八股文系列
    【Vue】Vue的Mustache插值语法、v-bind指令
    mac 解决 vscode 权限不足问题,Insufficient permissions
    前端三件套速成
    Java | interface 和 implements关键字【接口,看这篇就够了】
    C++高级面试题:解释 C++ 中的存储类别(Storage Class)
    5.静态库与动态库构建
    【随想】每日两题Day.2
  • 原文地址:https://blog.csdn.net/ak_bingbing/article/details/134483810