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

【爬虫】某某查cookie逆向

代码仅供技术人员进行学习和研究使用,请勿将其用于非法用途或以任何方式窃取第三方数据。使用该代码产生的所有风险均由用户自行承担,作者不对用户因使用该代码而造成的任何损失或损害承担任何责任。

加密参数

加密参数主要是cookie,其中只有三个cookie最重要,BAIDUID BAIDUID_BFESS 和一个ab开头的cookie

cookie获取

BAIDUID和BAIDUID_BFESS在访问百度系的产品时会由服务器返回,可以通过访问百度搜索引擎或者网站的首页进行获取,建议使用Session

ab开头的cookie

这个ab开头的cookie是绑定了你的UA的,所以不能用同一个cookie而使用不同的UA,UA和cookie和必须绑定

    def get_cookie(self, baidu_id, user_agent):
        s = '{}AIA{}'.format(user_agent, baidu_id)
        m = hashlib.md5(s.encode())
        a = m.hexdigest()
        time_str = str(time.time()).replace('.', '')[:13]
        i = a + time_str
        JS1 = '''
                              function a () { 
                                return "ab" + ("" + +new Date((new Date).getFullYear(),(new Date).getMonth(),(new Date).getDate(),(new Date).getHours())).substring(0, 9)
                              }
                              '''
        JS2 = '''
                              function a (i) {
                                s = [i[0], i[1], i.substring(2, i.length - 2), i[i.length - 2], i[i.length - 1]]
                                o = s[0] + s[3] + s[2] + s[1] + s[4]
                                return o
                              }
                              '''
        ctx1 = execjs.compile(JS1)
        ABname = ctx1.eval('a()')

        ctx2 = execjs.compile(JS2)
        ABvaule = ctx2.call('a', i)
        return {
            'BAIDUID': baidu_id,
            str(ABname): ABvaule,
            'BAIDUID_BFESS': baidu_id,
        }

通过这个cookie的生成逻辑可以看出他的值是由UA组成的 然后进行了MD5再进行了一些移位操作。
到现在网站需要的三个cookie已经全部拿到了

JA3指纹

到这里,其实代理IP的质量高一些,已经可以进行正常的采集,但是大多数情况下会出现采集一段时间后会疯狂的出现302跳转到旋转滑块,这是因为他检测了我们的JA3指纹

JA3指纹绕过

关于JA3指纹绕过可以看一下我之前的文章
python JA3指纹绕过

最后的一些思路

1、可以为BAIDUID搭建一个cookie池
2、不知道BAIDUID是否在服务端绑定了IP,即便突破了JA3还是会出现一些验证的情况


http://www.kler.cn/a/512924.html

相关文章:

  • Java 中 HashSet 集合元素的去重
  • 日历热力图,月度数据可视化图表(日活跃图、格子图)vue组件
  • LLMs(大型语言模型)的多智能体:Auto-GPT
  • 无人机高速无刷动力电机核心设计技术
  • ARP 表、MAC 表、路由表、跨网段 ARP
  • Kivy App开发之UX控件TabbedPanel选项面板
  • OpenAI 携手生物科技初创公司 Retro Biosciences 推出了一款全新 AI 模型 GPT-4b micro
  • Linux——线程条件变量(同步)
  • #CSS 实用属性总结
  • Android 解析蓝牙广播数据
  • Redis 数据存储类型
  • swin transformer中相对位置编码解析
  • PHP CRM售后系统小程序
  • 1. 基于图像的三维重建
  • 华为EC6110T-海思Hi3798MV310_安卓9.0_通刷-强刷固件包
  • Nginx正向代理配置
  • 微服务与docker
  • Three.js实现动态水泡效果逐步解析GLSL着色器
  • JavaScript网页设计案例-JavaScript实现数据脱敏的几种解决方式
  • Mac 刷题环境配置
  • C#语言的计算机基础
  • 80篇数据库大数据精华内容
  • 使用 Flask 构建视频转 GIF 工具
  • WinHttp API接口辅助类实现GET POST网络通讯
  • PostgreSQL的学习心得和知识总结(一百六十六)|深入理解PostgreSQL数据库之\watch元命令的实现原理
  • RabbitMq原生接口详解