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

知乎x-zse-96参数逆向实战:从断点调试到Python复现

1. 逆向分析前的准备工作第一次接触知乎x-zse-96参数逆向时我完全是个小白。记得当时为了抓取一些公开的问答数据直接用requests发请求却总是返回403错误。后来才发现知乎的接口有个关键的安全校验参数x-zse-96这个参数的值是通过前端JavaScript动态生成的。要逆向这个参数我们需要准备以下工具Chrome浏览器或其他现代浏览器开发者工具F12即可打开Python环境建议3.7execjs库用于执行JavaScript代码requests库用于发送HTTP请求在实际操作中我发现知乎的加密逻辑会不定期更新所以建议大家在分析时使用最新版的浏览器和网站代码。我第一次尝试时用的还是老版本的加密逻辑结果白忙活了半天。2. 定位x-zse-96生成位置打开Chrome开发者工具切换到Network面板然后访问知乎的搜索页面。在请求列表中找到接口请求通常是/api/v4/search_v3查看它的Headers部分就能看到x-zse-96参数。接下来我们需要找到这个参数的生成位置。在Sources面板中使用全局搜索CtrlShiftF查找x-zse-96。通常会出现2-3个结果我们需要在这些位置打上断点。我刚开始做这个逆向时犯了个错误——没有清除浏览器缓存就直接开始调试导致看到的代码是旧版本的。后来发现清除缓存后重新加载才能看到最新的加密逻辑。3. 分析加密逻辑组成通过断点调试我们发现x-zse-96的值是由2.0_加上一个加密字符串组成。这个加密字符串的生成过程可以分解为几个关键步骤首先会拼接一个基础字符串s它由以下几部分组成固定版本号如101_3_2.0请求的URL路径和参数cookie中的d_c0字段headers中的x-zst-81字段然后对这个字符串s进行两次加密处理第一次是f()函数处理实际上是MD5加密第二次是u()函数处理这是一个更复杂的加密过程我第一次分析时误以为u()函数是AES加密后来通过对比输出才发现是另一种加密算法。这个教训告诉我不能凭猜测一定要通过实际调试确认。4. 扣取关键JavaScript代码找到加密函数后我们需要把相关代码扣取出来。这里有几个技巧从u()函数开始往上找把依赖的函数都扣下来注意webpack的模块化结构可能需要把整个模块都复制出来特别留意环境依赖比如浏览器特有的对象或方法我遇到的坑是第一次扣代码时漏掉了一个很小的工具函数导致最后生成的签名总是对不上。后来通过对比浏览器环境和Node环境的执行差异才找到问题所在。扣下来的代码通常需要做一些调整移除webpack的模块包装补全缺失的全局对象如window、document等导出需要的函数以便调用5. 补全JavaScript执行环境扣下来的代码往往依赖浏览器环境我们需要在Node.js中模拟这些环境。常见需要补全的有window和document对象XMLHttpRequest等浏览器API加密相关的全局方法我推荐使用jsdom来补全环境它比较轻量且易于使用。安装方法很简单npm install jsdom然后在JavaScript文件开头添加const { JSDOM } require(jsdom); const dom new JSDOM(!DOCTYPE htmlpHello world/p); window dom.window; document window.document; XMLHttpRequest window.XMLHttpRequest;6. Python调用实现环境补全后就可以在Python中调用这些JavaScript代码了。这里我们需要用到execjs库import execjs import urllib.parse import requests # 读取JavaScript文件 with open(zhihu_encrypt.js, r, encodingutf-8) as f: js_code f.read() # 编译JavaScript代码 ctx execjs.compile(js_code) # 准备参数 params { t: general, q: python, correction: 1, offset: 0, limit: 20 } cookies {d_c0: 你的d_c0值} headers {x-zst-81: 你的x-zst-81值} # 生成签名 url_path /api/v4/search_v3? urllib.parse.urlencode(params) input_str f101_3_2.0{url_path}{cookies[d_c0]}{headers[x-zst-81]} signature ctx.call(get_signature, input_str) # 设置请求头 headers[x-zse-96] f2.0_{signature} # 发送请求 response requests.get( https://www.zhihu.com/api/v4/search_v3, headersheaders, cookiescookies, paramsparams ) print(response.json())在实际使用中我发现知乎的接口对请求频率有限制建议在代码中加入适当的延时避免被封IP。7. 常见问题与解决方案在逆向过程中我遇到过不少问题这里分享几个典型的签名验证失败最常见的问题是生成的签名不被服务器接受。这时候要检查各个参数拼接的顺序是否正确URL编码是否处理得当时间戳是否在有效期内环境缺失报错JavaScript代码执行时报错通常是缺少某些浏览器环境。可以通过console.log输出调试信息逐步排查缺失的对象或方法。请求返回403即使签名正确如果请求频率过高或行为异常也可能被拒绝。建议控制请求频率使用真实的User-Agent保持合理的请求间隔代码突然失效知乎偶尔会更新加密算法。遇到这种情况需要重新分析最新的加密逻辑。我建立了一个监控机制当请求开始大量失败时自动提醒我检查加密逻辑。8. 进阶优化建议对于需要长期稳定运行的项目我建议做以下优化缓存机制对一些不常变化的数据可以缓存签名结果减少计算开销。错误重试实现自动重试逻辑当请求失败时自动重新生成签名并重试。分布式部署如果需要大规模采集可以考虑分布式部署避免单IP被封。自动更新监控加密逻辑变化当发现签名失效时自动触发更新流程。我在实际项目中还实现了一个小技巧定期自动验证签名的有效性。通过定时访问一个固定接口检查返回状态可以在用户发现问题前就发现加密逻辑的变化。逆向工程最有趣的地方在于它就像解谜游戏每次成功破解一个参数都很有成就感。不过也要提醒大家这类技术应该用在合法合规的场景尊重网站的数据使用政策。

相关文章:

知乎x-zse-96参数逆向实战:从断点调试到Python复现

1. 逆向分析前的准备工作 第一次接触知乎x-zse-96参数逆向时,我完全是个小白。记得当时为了抓取一些公开的问答数据,直接用requests发请求却总是返回403错误。后来才发现,知乎的接口有个关键的安全校验参数x-zse-96,这个参数的值是…...

从果园到代码:手把手教你用YOLOv5+DeepSort实现猕猴桃自动计数(附避坑指南)

从果园到代码:手把手教你用YOLOv5DeepSort实现猕猴桃自动计数(附避坑指南) 盛夏的果园里,阳光透过茂密的枝叶洒在成串的猕猴桃上。果农老王正拿着记录本,一株株清点着今年的收成。"这活儿太费眼了,数着…...

SDD基于规范编程-OpenSpec及SuperPowers伟

智能体时代的代码范式转移与 C# 的战略转型 传统的 C# 开发模式,即所谓的“工程导向型”开发,要求开发者创建一个复杂的项目结构,包括项目文件(.csproj)、解决方案文件(.sln)、属性设置以及依赖…...

WPF无边框窗口最大化时避免遮挡任务栏的终极方案

1. 为什么无边框窗口会遮挡任务栏? 很多开发者在使用WPF开发自定义窗口时,都会遇到一个头疼的问题:当窗口设置为无边框(WindowStyle"None")并最大化时,窗口会遮挡系统的任务栏。这个问题看似简单…...

得意黑Smiley Sans:一款能让你爱上中文排版的窄斜体黑体终极指南

得意黑Smiley Sans:一款能让你爱上中文排版的窄斜体黑体终极指南 【免费下载链接】smiley-sans 得意黑 Smiley Sans:一款在人文观感和几何特征中寻找平衡的中文黑体 项目地址: https://gitcode.com/gh_mirrors/smi/smiley-sans 你是否厌倦了千篇一…...

AI原生敏捷开发落地指南(Gartner 2024验证:交付周期压缩63%的关键转折点)

第一章:AI原生敏捷开发的范式跃迁 2026奇点智能技术大会(https://ml-summit.org) 传统敏捷开发以人为核心、迭代交付为特征,而AI原生敏捷开发则将大模型能力深度嵌入需求分析、测试生成、代码补全与运维反馈闭环中,形成“感知—推理—执行—…...

CentOS 7.6服务器上,用FileZilla搞定VOS3000 8.0安装与授权(附详细命令)

CentOS 7.6服务器上高效部署VOS3000 8.0的完整指南 在当今VoIP业务快速发展的背景下,稳定可靠的通信系统部署成为企业运营的关键。本文将详细介绍如何在CentOS 7.6服务器上,结合FileZilla等工具,完成VOS3000 8.0的专业级部署与授权流程。不同…...

保姆级教程:用PaLI-X和PaLM-E微调你自己的RT-2风格机器人模型(附避坑指南)

从零构建RT-2风格机器人模型:基于PaLI-X/PaLM-E的实战指南 当我在实验室第一次看到RT-2模型准确识别出"即将倾倒的杯子"并实施救援动作时,意识到具身智能的临界点已经到来。这不是简单的物体抓取,而是机器对物理世界的因果推理——…...

Q、K、V大揭秘:小白也能看懂的自注意力机制,助你入门大模型(收藏版)

本文用大白话解释了自注意力机制中的核心元素Q、K、V,通过图书馆找书的类比,说明了Q代表查询指令、K代表索引标签、V代表实际内容。文章阐述了Q、K、V如何协同工作,实现精准的信息匹配和加权整合,帮助读者理解大模型如何处理全局信…...

SGP40气体传感器I²C驱动与嵌入式移植实战

1. SGP40气体传感器底层驱动技术解析1.1 传感器核心特性与工程定位SGP40是瑞士Sensirion公司推出的数字式挥发性有机化合物(VOC)气体传感器,专为室内空气质量监测、智能家电和IoT终端设计。其核心价值不在于直接输出ppm级VOC浓度,…...

SpringCloud进阶--Sentinel 流量防卫兵弛

一、项目背景与核心价值 1. 解决的核心痛点 Navicat的数据库连接密码并非明文存储,而是通过AES算法加密后写入.ncx格式的XML配置文件中。一旦用户忘记密码,常规方式只能重新配置连接,效率极低。本项目只作为学习研究使用,不做其他…...

从Matlab到FPGA:CIC滤波器设计验证全流程(附可下载的Verilog代码与测试脚本)

从Matlab到FPGA:CIC滤波器设计验证全流程实战指南 在数字信号处理领域,CIC(Cascaded Integrator-Comb)滤波器因其无需乘法器的硬件友好特性,成为数字下变频、采样率转换等场景的首选方案。本文将带领算法工程师和FPGA开…...

Hagicode.Libs:统一集成多个 AI 编程助手 CLI 的工程实践郝

1. 什么是 Apache SeaTunnel? Apache SeaTunnel 是一个非常易于使用、高性能、支持实时流式和离线批处理的海量数据集成平台。它的目标是解决常见的数据集成问题,如数据源多样性、同步场景复杂性以及资源消耗高的问题。 核心特性 丰富的数据源支持&#…...

Claude Code Auto Mode 的技术实现

Claude Code Auto Mode 通过智能代码补全和上下文理解提升编程效率。该模式能自动分析当前代码上下文,预测开发者意图,提供精准的代码建议。支持多种编程语言,包括Python、JavaScript、Java等主流语言。深度学习模型实时学习项目代码风格和模…...

uni-app上传图片总失败?可能是你没处理好这几个细节(uni-file-picker实战排雷)

uni-app图片上传疑难排查指南:从临时路径到稳定交付的完整解决方案 在移动端开发中,文件上传功能看似简单,却暗藏诸多"坑点"。最近接手一个电商项目时,我们团队在uni-file-picker组件上栽了跟头——用户上传的图片时而显…...

mbino:Arduino上实现mbed HAL的轻量级嵌入式抽象层

1. 项目概述mbino 是一个面向 Arduino 平台的轻量级嵌入式抽象层移植库,其核心目标是将 mbed OS 2 的标准化硬件抽象 API(Hardware Abstraction Layer, HAL)无缝引入以 AVR 8-bit 微控制器(如 ATmega328P、ATmega2560)…...

diffusion model的基本概念

主要分为两个步骤:加密加噪声让原图变成模糊图(Forward Process),将模糊图去噪声,让其变成清晰图(Reverse Process) 先说Recerse Process的过程本质就是去除掉无用的像素,让有用的像素留下来(类似加密与解密…...

信息时代的内容创作者,你离“爆款“只差一个正确的信息入口

说实话,作为一个在互联网内容行业摸爬滚打七八年的老编辑,我早就被各种信息轰炸得有些麻木了。每天早上醒来,手机里躺着十几个App的推送通知,微信群里几百条未读消息,邮箱里塞满了各类资讯订阅。想要快速了解今天发生了…...

OpenGL多线程踩坑实录:EGL_BAD_ACCESS错误排查与修复指南

OpenGL多线程开发中的EGL_BAD_ACCESS:从原理到实战解决方案 当你在深夜调试一个复杂的OpenGL多线程应用时,突然在终端看到EGL_BAD_ACCESS错误提示,那种感觉就像在高速公路上爆胎——既焦虑又无助。这个错误在多线程OpenGL开发中极为常见&…...

Redis高危漏洞CVE-2025-49844(RediShell)详解:13年Lua脚本UAF漏洞可实现远程代码执行(RCE)

Download Redis Logo in SVG Vector or PNG File Format - Logo.wine Redis官方已针对CVE-2025-49844漏洞发布安全公告。该漏洞是Lua脚本引擎中的“释放后使用”(Use-After-Free,UAF)内存损坏问题,可被已认证攻击者利用恶意Lua脚…...

GyverMAX7219:亚毫秒级LED矩阵图形库深度解析

1. 项目概述GyverMAX7219 是一款专为 MAX7219 驱动芯片设计的高性能、轻量级嵌入式图形库,面向资源受限的微控制器平台(如 ATmega328P、ESP32、STM32F1/F4 等)提供毫秒级响应的 LED 矩阵控制能力。其核心定位并非通用显示驱动,而是…...

无人机测绘新手避坑:为什么你的TIN模型总是有‘尖刺’和空洞?

无人机测绘实战:TIN模型尖刺与空洞问题的深度解析与解决方案 当你在ContextCapture或Pix4D中点击"生成TIN模型"按钮时,是否曾盯着屏幕上那些诡异的尖刺和黑洞陷入沉思?这些不速之客不仅影响模型美观,更会直接导致体积计…...

告别裸奔!用CubeMX+ThreadX给STM32H743项目快速搭建一个健壮的任务框架

基于CubeMX与ThreadX构建STM32H743高可靠实时系统框架 在嵌入式开发领域,从裸机编程过渡到RTOS(实时操作系统)往往意味着项目复杂度与可靠性的双重提升。对于使用STM32H743这类高性能MCU的开发者而言,如何快速搭建一个既稳定又易于…...

深夜告警炸裂?这份Linux故障排查“作战地图”请收好劣

先唠两句:参数就像餐厅点单 把API想象成一家餐厅的“后厨系统”。 ? 路径参数/dishes/{dish_id} -> 好比你要点“宫保鸡丁”这道具体的菜,它是菜单(资源路径)的一部分。查询参数/dishes?spicytrue&typeSichuan -> 好比…...

2、 Verilog 代码规范

分类 Verilog 教程高级篇 不经意间看到几年前自己写的 FGPA 设计,代码风格勉强说的过去,但是逻辑设计方面的安全隐患比比皆是。许多初学者编写 Verilog 代码,基本都是按照 C 语言的思维和风格去设计,造成了很多不规范的共性问题。…...

【生成模型】【ComfyUI(四)】WebSocket实时监控与进度条优化ComfyUI批量处理

1. WebSocket实时监控的原理与实现 ComfyUI作为生成模型的重要工具,其批量处理能力直接影响工作效率。传统轮询方式会造成资源浪费和延迟,而WebSocket协议的全双工通信特性完美解决了这个问题。我曾在实际项目中处理过300图像的批量生成任务,…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语劣

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作量。 使用 kube…...

不满意Oh My Zsh启动卡顿,来试试Starship吧谱

pagehelper整合 引入依赖com.github.pagehelperpagehelper-spring-boot-starter2.1.0compile编写代码 GetMapping("/list/{pageNo}") public PageInfo findAll(PathVariable int pageNo) {// 设置当前页码和每页显示的条数PageHelper.startPage(pageNo, 10);// 查询数…...

2026年外墙保温一体板企业口碑大揭秘,哪家更值得信赖?

随着建筑行业的不断发展,外墙保温一体板因其优异的保温性能和美观性,逐渐成为市场上的热门产品。然而,市场上品牌众多,消费者在选择时往往感到困惑。本文将通过具体数据和案例,分析几家主要的外墙保温一体板企业&#…...

ChibiPIO-STM32F0:专为Cortex-M0优化的ChibiOS定制发行版

1. 项目概述ChibiPIO-STM32F0 是一个面向 STM32F0 系列微控制器的定制化 ChibiOS/RT 嵌入式实时操作系统发行版,其核心定位并非独立开发的新RTOS,而是对上游 ChibiOS/RT 源码树进行深度裁剪、适配与封装后的专用构建产物。它完整继承 ChibiOS/RT 的轻量级…...