js逆向-某头条_signature参数

news2025/1/10 17:51:10

前言

头条的加密参数_signature其实可以通过搜索来直接定位到关键位置,我们换种定位的方法
在这里插入图片描述

定位

先查看下堆栈,直接在第一个XMLHttpRequest.send的位置下上断点,然后下拉触发断点
在这里插入图片描述
这个位置还有其他请求,这里只看/api/pc/list/feed,可以看到this的openArgs里面的uri参数已经包含了_signature,所以我们追上面的堆栈
在这里插入图片描述
前面的那些栈就不看了,因为并没有找到this.openArgs被赋值的地方,直接看下面的这个
在这里插入图片描述
var h = new XMLHttpRequest;下上断点,并取消之前所有的断点
在这里插入图片描述
可以看到url是在h.open这一行被赋值的,e.params就是请求的参数
在这里插入图片描述
e来源于上面的参数,在第一行打上断点,然后往前翻堆栈
在这里插入图片描述
同样在上一层的第一行打上断点,因为e又是来源于参数
在这里插入图片描述
这时候堆栈没有上一层了,说明是异步调用的,看Promise.then(async) 里的调用栈。点第一个c.request
在这里插入图片描述
关键代码在上图中的框起来的那个循环(当然这个是后话,因为单从这里无法判断这里就是加密的关键位置,需要单步走下去看看e到哪里生成的),下面的代码是先往t数组中push一些函数,unshift和push是一个意思,只是加到数组的头部

this.interceptors.request.forEach((function(e) {
	t.unshift(e.fulfilled, e.rejected)
}
)),
this.interceptors.response.forEach((function(e) {
    t.push(e.fulfilled, e.rejected)
}
))

然后进入循环,打上断点,可以看到n就是Promise

for(;t.length;){
	n = n.then(t.shift(), t.shift());
}

上面的代码修改成同步的,数组的函数就是this.interceptors.requestthis.interceptors.response两个数组里面的函数

for(;t.length;){
	// 弹出t数组头部的第一个元素
	var fulfilled = t.shift();
	// 执行这个函数
	fulfilled();
	var rejected= t.shift();
	rejected();
}

可以看出t里面有十个元素,其中有五个函数,点进去第一个看看代码
在这里插入图片描述
来到了下面的代码,因为是请求加密所以我们只看interceptors.request就可以了,正常的话是在所有的interceptors.request函数里都打上断点,但是下面的代码已经很明显出现了_signature: n,所有先在这一行打上断点
在这里插入图片描述
加密代码就是var n = I(F.getUri(e), e);这个,F.getUri(e)的值是/api/pc/list/feed?channel_id=0&max_behot_time=1676120482&category=pc_profile_recommend&aid=24&app_name=toutiao_web,这个就是url里面的uri。e是一个包含很多内容的对象,先不管,先进去I函数里面看看
在这里插入图片描述

函数看起来有很多行,简化一下就下面几行

function I(e, t){
	var r = "https://www.toutiao.com";
	var o = {
		url: r + e
	};
	return window.byted_acrawler.sign(o);
}

关键就在于window.byted_acrawler.sign这个函数,鼠标悬上面,然后点进去看一下
在这里插入图片描述
进到acrawler.js
在这里插入图片描述
也就是说window.byted_acrawler.sign是这个js里面导出的函数,那么只需要运行这个js就可以得到window.byted_acrawler对象了

新开一个标签页,在snippets创建一个脚本,然后把acrawler.js内容复制到里面,可以看到最开始window.byted_acrawler是没有值的,运行这个js后就出现了值
在这里插入图片描述
测试一下加密,发现加密的结果短了很多。这里看过其他文章就知道,是因为少了cookie,只要加上cookie,结果就是长的
在这里插入图片描述

补环境

这个就不说了,我也是用的别人的框架。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/339285.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023 AIME 答案与解析 - 第二期(完结)

原题目 Find the number of cubic polynomials where and are integers in such that there is a unique integer with 绿树教育中心独家解析 是一个有两个整数根的三次方程,因此它有三个整数根。所以, 或 ,其中 。 「Case 1」 ,则…

关于spring bean的生命周期的个人理解(根据官方文档学习)

首先说一下Servlet的生命周期:实例化,初始init,接受service,销毁destroy; spring上下文中的Bean 生命周期也是类似,如下: (1)实例化Bean 对于Bean Factory容器&#xf…

elasticsearch更新和删除

文档更新文档的更新经历三个步骤,检索、修改、重新索引部分更新在原有文档已经存在的情况下,可以对原有的文档部分字段更新,使用POST请求,发送到/_update如果文档是不存在的,更新操作是失败的存在则更新,不…

Qt C++ 自定义仪表盘控件02

简介仪表盘是工控领域不可缺少的一类软件UI元素,通常出现在各类电子看板软件上,以及一些高级的上位机软件界面上,目的是将繁杂的数据转化为可视化的图表能大幅提高后台管理效率。本文分享了几个经典常用的仪表盘控件,在项目中可以…

利用升序定时器链表处理非活动连接

参考自游双《Linux高性能服务器编程》 背景 服务器同常需要定期处理非活动连接:给客户发一个重连请求,或关闭该连接,或者其他。我们可以通过使用升序定时器链表处理非活动连接,下面的代码利用alarm函数周期性的触发SIGALRM信号&a…

半人半妖时代来啦

未来是半人半妖时代!!! 碳基生命与硅基生命结合 趣讲大白话:人和机器结合是大趋势 *********** 人工智能就是宗~教 科技宗~教的一支最强势的教派 日常使用智能机器的人就是信众 维护机器的人就是牧师 创造这…

【mock】手把手带你用mock写自定义接口+mock常用语法

mock自定义接口完整流程 官网语法规范:https://github.com/nuysoft/Mock/wiki/Syntax-Specification 首先: 要有一个项目,我这里是vue3项目,以下从vue3项目搭建开始,已搭建好的请直接看2 1.空目录下新建vue3项目 运行创建项目命令: 在bash中:(文件路径处输入cm…

【计组】内存和总线--《深入浅出计算机组成原理》(十)

课程链接:深入浅出计算机组成原理_组成原理_计算机基础-极客时间 一、虚拟内存和内存保护 日常使用的操作系统下,程序不能直接访问物理内存。内存需要被分成固定大小的页(Page),再通过虚拟内存地址(Virtu…

卡通形象人物2 写代码-睡觉 丝滑如德芙

目录 本次实现效果 目录结构 index static/css/style.css static/js/script.js 结语: 前期回顾 【 css动画 】—— 把你喜欢css动画嵌入到浏览器中_0.活在风浪里的博客-CSDN博客常用酷炫动画999合集,代码直接复制可用,总用你想找的…

【Java】 JAVA Notes

JAVA语言帮助笔记Java的安装与JDKJava命名规范JAVA的数据类型自动类型转换强制类型转换JAVA的运算符取余运算结果的符号逻辑运算的短路运算三元运算符运算符优先级JAVA的流程控制分支结构JAVA类Scanner类Math 类random方法获取随机数Java的安装与JDK JDK安装网站:h…

AXI 总线协议学习笔记(4)

引言 前面两篇博文从简单介绍的角度说明了 AXI协议规范。 AXI 总线协议学习笔记(2) AXI 总线协议学习笔记(3) 从本篇开始,详细翻译并学习AXI协议的官方发布规范。 文档中的时序图说明: AXI指&#xff1…

基础面试题:堆和栈的区别

面试题:堆和栈的区别(往往讲的是内存zha) 为什么说访问栈栈比访问堆快些? 目录 一、数据结构中的堆栈 1、数据结构中的堆 1)堆的定义 2)堆的效率 2、 数据结构中的栈 二、内存中的堆栈 1、内存堆的定义…

Stm32 for arduino STM32G071GBU6 I2C and SERIAL

文件目录: C:\Users\Administrator\AppData\Local\Arduino15\packages\STMicroelectronics\hardware\stm32\2.3.0\variants\STM32G0xx\G071G(6-8-B)U_G081GBU boards_entry.txt Generic G071GBUx GenG0.menu.pnum.GENERIC_G071GBUXGeneric G071GBUx GenG0.menu.pnum.GENERIC…

SpringMVC:统一异常处理(11)

统一异常处理1. 说明2. 问题描述3. 异常处理器使用3.1 创建异常处理器类3.2 让程序抛出异常3.3 测试4. 项目异常处理方案4.1 异常分类4.2 异常解决方案4.3 异常解决方案的具体实现4.4 测试5. 总结1. 说明 \quad本篇文章是在文章SpringMVC:SSM整合(Spring…

【Vuex 源码学习】第六篇 - Vuex 的模块收集

一,前言 上一篇,主要介绍了 Vuex 中 Mutations 和 Actions 的实现,主要涉及以下几个点: 将 options 选项中定义的 mutation 方法绑定到 store 实例的 mutations 对象;创建并实现 commit 方法(同步&#x…

最近挺火的人工智能chatGPT注册

文章目录1.前提预备1.1 短信接收平台1.2 ip加速,不做说明2.注册chatGPT步骤2.1 进入chat.openai.com网址后,点击sign up2.2 可以使用qq邮箱注册2.3 填写好邮箱,然后点击Continue,然后再填写密码2.4 之后在qq邮箱进行验证注册(注意&#xff1a…

C++入门——内存管理

C入门——内存管理 C/C内存分布 分类是为了更好的管理 int globalVar 1; static int staticGlobalVar 1; void Test() {static int staticVar 1;int localVar 1;int num1[10] {1, 2, 3, 4};char char2[] "abcd";char* pChar3 "abcd";int* ptr1 (…

Java、JSP环境保护与宣传网站的设计与实现

技术:Java、JSP等摘要:本文对环境保护与宣传网站的设计和开发过程进行了详细地分析与叙述。按照系统开发的实际操作流程以及论文编写的规范,论文内容从系统概述、系统分析、系统设计和系统实现这四大模块对系统的开发过程分别进行了阐述。系统…

python3-API流量回放/锲约测试/自动化测试

PPL-Tester 简介 http工具集,通过代理获取到API的请求与响应信息,将这些请求信息进行流量回放/锲约测试或快速生成用例, 亦可通过人工进行修改参数化提取、变量引用、断言等形成API自动化测试用例等! 你以为只是流量回放吗?错~走去瞧瞧v2版本! 看官~请记得给个star呗? 项…

驱动 | Linux | NVMe - 1. 概述

本文主要参考2篇相关的解析 1’ 2 和 linux 源码 3。 此处推荐一个可以便捷查看 linux 源码的网站 bootlin 4。 更新:2022 / 02 / 11 驱动 | Linux | NVMe - 1. 概述与nvme_core_init函数解析NVMe 的前世今生NVMe CommandPCI 总线从架构角度看 NVMe 驱动NVMe 驱动的…