当前位置: 首页 > news >正文

python爬虫:喜马拉雅案例(破解sign值)

声明: 

本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提供完整代码,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!

本文章未经许可禁止转载,禁止任何修改后二次传播,擅自使用本文讲解的技术而导致的任何意外,作者均不负责,若有侵权,请联系作者立即删除!

根据上一篇文章,我们破解了本网站的,手机号和密码验证,这篇文章我们继续破解sign加密值 python爬虫:喜马拉雅登录案例-CSDN博客

  •  我们今年天要破解的就是请求加密的sign值(箭头所指):

 前置知识点:判断加密值可能采用哪种算法

  • 我们这个案例的sign值是:3dc612f47e51715f62e0d1ab66490637c16b4851
  • 这个值的长度是40,我们就可以找找网上的加密网站 SHA1 在线加密工具 | 菜鸟工具
  • 我们可以挨个试一下,只有sha1算法符合我们的sign,我们就推断sign值可能是使用的啥sha1算法加密

 1. 找到我们之前的加密入口进行观察(找到signnature),我们判断应该与e有关

  •  在这一张图中,我们看到它定义了e,所以我们应该点进a.getSignature中查看js源代码代码如下
var e = (0,
            a.getSignature)({
                account: n,
                password: i,
                nonce: t
            });
  •  悬浮鼠标,点进源码,查看源码,复制、粘贴源码:

 

 2. 把代码复制到Pycharm中进行调试

  • 其中我们知道n,i是我们之前逆向出来的值,none可能是固定值、也有可能是变化值

  •  在调试过程中,代码出现了错误,如下图:

  •  我们就发现错误,但是读代码我们就可以看出,这个函数是将n、i、t的值今昔那个拼接,js代码可以处理,python也可以处理(这里我们就使用js进行处理把,有基础的可以试一试使用python去处理)

 

  •  解决了y的错误,我们需要解决d的错误(这里的d看着像是个固定值),我们直接把固定值拿过来

3.最后我们就破解了它的sign值

  • 代码如下: 
cryptoJs = require("crypto-js")

d = "WEB-V1-PRODUCT-E7768904917C4154A925FBE1A3848BC3E84E2C7770744E56AFBC9600C267891F"

function y(t) {
    var e = ""
        , r = Object.keys(t).sort((function (t, e) {
            return (t = t.charCodeAt(0)) - (e = e.charCodeAt(0))
        }
    ))
        , n = r.length;
    return r.forEach((function (r, o) {
            var i = t[r];
            e += "".concat(r, "=").concat(i),
            o < n - 1 && (e += "&")
        }
    )),
        e
}


function getSignature() {
    var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {}
        , e = y(t) + "&" + d;
    return e.toUpperCase(),
        cryptoJs.SHA1(e.toUpperCase()).toString()
}

let n = "duWIGfpxabRcy5On5nyp37xK6r5JsL5vvzBC40SnqBl+ahQaKibOnJXeAWjOOWO8mOMQGnxxF1GyOpclRAdOkJvMb1ELSFqgFBbilqUtZipPJzzFyaRUMmbI+W9+m7VBDV1gAGwxUpj79M4x6ksl62QQrxm4k/IYybO9x9tZiFg="
let i = "Y2OZqFIfMpmKcIM98fOedsuwN0KHfvSlSQq6ugie7cYKH2F5hd3c6tXoKTzqeBkTKPo4qgbelCKLOvRdkShls0rBHuwEUZ4z2WJSyYSKG96natp7XhopHh27UUDGQX1BHSlNu8g0axx5WG9e9wEKKIhh2pz/LhbcZcBfAQ6qD9s="
let t = "0-29DAD105A65486c80bf90ec611605af8df9feffc8ec85e24e195efdc8e36d5"

// 测试
ret = getSignature({
    account: n,
    password: i,
    nonce: t
});

console.log(ret)

相关文章:

  • 以库存系统为核心的ERP底层架构设计
  • git单独跟踪远程分支及处理合并异常情况
  • 蓝桥杯嵌入式第十五届
  • C++【string类】(一)
  • C语言关键字
  • 认识 Linux 内存构成:Linux 内存调优之虚拟内存与物理内存
  • DAY 39 leetcode 18--哈希表.四数之和
  • 支持企业知识库和联网搜索,360AI企业知识库驱动业务深度融合
  • 小刚说C语言刷题——第19讲 循环之continue和break
  • 计算机网络(1)
  • 【SpringCloud】从入门到精通(上)
  • GPT-SoVITS Windows 配置与推理笔记(自用)
  • JVM虚拟机篇(六):深入理解Java垃圾回收机制
  • 有反驳的意思的英语单词
  • Python----概率论与统计(概率论,互斥事件和概率和,非互斥事件和概率和,独立性事件,生日问题,条件概率)
  • ARM内核与寄存器
  • java 洛谷题单【数学1】基础数学问题
  • 一款基于 .NET 8 + Vue 开源的、企业级中后台权限管理系统
  • 设计模式 Day 6:深入讲透观察者模式(真实场景 + 回调机制 + 高级理解)
  • Every ending plants the seed for a new beginning.
  • 在虚拟主机上建设多个网站/搜索引擎优化方法有哪几种
  • 眉山政府网站建设/竞价推广营销
  • 网站的落地页/360网站安全检测
  • 为什么不能用来名字做网站名/广州seo公司排行
  • 重庆 网站设计/百度免费推广平台
  • wordpress商城 中文站/发稿