• 【JS逆向 + python模拟获取】今天逆向一个简单的半混淆网站,获取token的生成方法,并用python模拟获取数据


    逆向日期:2024.02.20

    使用工具:Node.js、python

    加密工具:Crypto-js标准库

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

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

    【点赞 收藏 关注 】仅供学习,仅供学习,
    1、打开某某网站(请使用文章开头的AES在线工具解密):/zf4dYpaVbBna4oFFFS+lXiskGNj9rKuHiy8z+D57/Lb1mqzgSuIUTJKfYJjLJIs
    2、打开网站后,翻页抓包,控制台查看,这就是我们要逆向的【token】值

    3、全局搜索,打断点,翻页,断住了,每次加密结果不一样,长度较短,直接排除RSA加密,目测为AES、DES、Base64加密,,里面应该有时间戳,这个token的唯一作用就是反爬虫的,会将token传递给服务器,服务器进行验证后,会看这个token有没有过期,是不是正确的加密方法。但对于会js逆向的爬虫工程师来说,就有点多余,,,直接断点步入进去

    4、步入进来后,可以看到他用了一个【crypto】标准库,然后传递进来了一个固定参数【/api/movie】,然后经过循环添加了一个时间戳,然后用sha1加密,加密后的结果在与之前的时间戳合并,然后在进行Base64加密,得出的结果就是token了

    5、我们直接本地模拟一下,然后看看结果是否和上面那个图的结果一样 ,,测试完成后,我们将那个时间戳改成实时生成的,然后我们取用python模拟测试一下

    6、js直接优化一下,然后python直接模拟成功获取数据

    【附上源码】

    【token.js】

    1. // 安装 crypto 加解密包
    2. // npm install crypto-js --save
    3. const CryptoJS = require('crypto-js')
    4. function token(){
    5. o = '/api/movie'
    6. t = Math.round((new Date).getTime() / 1e3).toString()
    7. data = [o,t].join(',')
    8. c = CryptoJS.SHA1(data).toString()
    9. data = data = [c,t].join(',')
    10. a = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(data))
    11. return a
    12. }

    【token.py】  此处的密文需要经过AES加解密工具工具后得出python代码

    JXtvLmP9Dt9/JkkmxV1w1+V6TviFL10uR2oSMSsPES7brQRzziFlUrZ2Vdyapj9OTMw8bGgH1pApGTbedfjZKDGfc9jnv4z3sNWq3wPuJm2RQVX0Hj2OLXG+PExHncPsS+XjJnIJXG9C3fdpaGTuCG6RLC0kd7mjrxvknb2Rvc0/OQPugJWhuK2gRiF6i5S+4mlmZzIt/LQsDfl1yaFpIGTX620aXDR3C+zwLetYIWlYAeEKzFTgOBl/f+GX2QykcCtCBICUmsVnKC2joTY8gfnk/z3GUQrYGTluPqvpIpMKVeGtJJTJXYVRRXdP45yTS2lqsv32AtMFU1xGEWfn55Ghunhf6HNVVCjBlxT4+6lDEbEDUmHYdQ0sQZ/NKPFlsUtmi6iVYFIFyEoaXTeIxes2ZGCJeChofQ/tVEnpUsz4UuJapn5of7ZuW7tS3g6G/0sYtJ3DF96dTfIHNWPYESUeLSSIT2IO3NovxuyTgDx1wg0a9wl126jHi0CGmNcADMBGq8cAQZqlAmZ1CrtNwIVnsyM57cgWiJcSGjnfbPbA7paFIqJa7e8hQOxlX57gVrvh9nvkEH+mfGAVId6NiIPrPgdJ+wW0CjIp4HEJCB9o5hoWPGcQ6x07vK8a8CEKVRjBGcW0+e1iWsYURFmd46U2Y8bAftXreo69kK/Pro9oYs1Y0z6u/3OFqSt88bWpf0oXogFakr14Mrh9xgevnEAAyzXsbro0hcEC+1XWv3HOqPDES/3hBIJLRo0MRmYTfi8+XdfDW9ZQYHntv+AQd+BNlfGAlsh6G5jVC9QO9NooaLaw6GeH3SB3fE+Byp4p6VeJec5Nf3Z83Ogu2oTUUgqexXuRMLIP3NkR4pUCmNqdN+iPU0YMFHSa4xARZ8aZgWrtJ2I6Dc51iIQ2ZBVoRA==

  • 相关阅读:
    解决IDEA下载mysql驱动太慢
    掌握 BERT:自然语言处理 (NLP) 从初级到高级的综合指南(1)
    STM32单片机PID控制数控恒流源-100mA~+100mA输出正负恒流源
    代码随想录刷题|LeetCode 198.打家劫舍 213.打家劫舍II 337.打家劫舍III
    cmake vs openmp
    分组统计查询
    【Python教学】pyqt6入门到入土系列,超详细教学讲解
    生产消费者模型的介绍以及其的模拟实现
    TensorFlow 中的 Conv2DOp
    Linux入门教程:P15->软件包管理
  • 原文地址:https://blog.csdn.net/weixin_46625757/article/details/136197211