最新版B站刷播放量接口协议参数(w_rid、aid、cid、buvid3、b_lsid、cookie),加密算法全流程解析

本文主要是介绍最新版B站刷播放量接口协议参数(w_rid、aid、cid、buvid3、b_lsid、cookie),加密算法全流程解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作为巨大流量池B站,有必要对其数据接口做一番全流程分析;下面梳理一下各个参数的获取方法,以作为学习交流之用。

话不多说, 先找接口 -》

根据测试和综合网上资料(经验也重要啊!)增加播放量的按钮接口在这个h5的链接, 只有访问这个链接接口,才能记作播放一次,那么接下来就是构造请求了:

看看请求参数 cookie , payload 那么参数 泪目。。 爬虫工作量还是很大的),这里面参数都要一一构造, 理论上错一个也不行啊;

那就来呗=》 先从cookie下手, cookie来源主要有一下:服务器发给客户端的,在response cookie可以找到,  根据一定条件(比如拿url中几个请求参数param)放进JS代码里面加密生成的, 客户端拿了一个cookie之后,二次发起请求向服务器获取新的cookie值的 

往上挨个链接找cookie值,幸运的是在抓包的第一次访问链接里面几个关键cookie值 ,比如buvid3,b_nut  

还有在response里面发现了参数 cid , aid  seesion等值, 好吧!进老鼠窝了, 一锅端了!

用python首条链接发起请求,获取cookie, 用正则把response里面的cid,aid ,session给它择出来。

def get_buvid3():bvid='BV1tN4y1Y7i8'response = requests.get(f'https://www.bilibili.com/video/{bvid}/', headers=headers)data_list=re.findall(r'__INITIAL_STATE__=(.+);\(function',response.text) # .表示除换行符所有字符,+ 表示一个或者多个data_dict=json.loads(data_list[0]) # 结果长得像字典, 就用python中反序列化转成json格式sessionId=re.findall(r'session":"(.+)"}</script',response.text)[0]aid=data_dict['aid']cid=data_dict['videoData']['cid']buvid3=response.cookies.get_dict()['buvid3']b_nut=response.cookies.get_dict()['b_nut'] #1704092097return {'buvid3':buvid3,'aid':aid,'cid':cid,'b_nut':b_nut,'session':sessionId}
pprint.pprint(get_buvid3())

 接着往上找参数

来到叫spi的这api接口, 在response找到了宝贵的两个参数 buvid3  buvid4 ,准备发起请求拿下这两个值,

看下构造请求参数:

好嘛! cookies里面增加了sid ,b_lsid的值,搁着玩碟中谍呢?!参数越变越多了, 现在还得把两小弟搞定,下来要开始逆向了。

 搜索b_lsid值,在log-reporter.js有出现,  在这里说一下, cookie里面的逆向有一大特点,就是最终会把生成好的cookie放在一个setCookie的函数里面,这样找起来就排除了很多干扰项,如图所示:

 找到了疑似目标位置之后好办,通过一系列断点调试,等骚操作之后(中间也是百转千回),浓缩成一段python代码来集成这个 b_lsid值,本着拿来主义, 直接上吧:

def get_b_lsid():data=""for i in range(8):v1=math.ceil(16*random.uniform(0,1))v2=hex(v1)[2:].upper()data+=v2result=data.rjust(8,"0")e=int(time.time()*1000)t=hex(e)[2:].upper()b_lsid="{}_{}".format(result,t)return b_lsid

搞定这个值之后,革命还在继续中。。

sid值 

这个值的获取是response cookie服务器返回的, 通过构造请求就可以获取, header头链接在一个叫v2?aidxxxxxx的链接中, 

payload中, 又有新成员加入, 好嘛!还在连环套中。。

w_rid , 搜索中只有JS文件中有,不用多说, 又是一轮新的JS逆向之旅了;

 在这个文件中有, 而且还是md5函数 ,出于职业敏感, 看到这种md5什么的,基本属于自报家门了!果断打上断点 

不着急,出于严谨,还有一处 ,在  core.xxxx.js这个文件也有一处类似的函数, 可别漏网之鱼呀,都打算断点, 看它走哪一处!

断点停在了这个JS中这个位置, 另外一个JS人家压根不断 !

根据打印的中,看看参数,瞧瞧返回值, 大概能看看七七八八了, 

var r = getWbiKey(t) ,r: {imgKey: '7cd084941338484aae1ad9425b84077c', subKey: '4932caff0ff746eab6f01bf08b70ac45'}

嫌疑在这, 确定imgKey ,subKey 这两个值, 可以说是本次逆向的精华所在了!

def web_rid(param):# n = "653657f524a547ac981ded72ea172057" + "6e4909c702f846728e64f6007736a338"n = imgKey+ subKeyr = []c = ''.join([n[i] for i in[46, 47, 18, 2, 53, 8, 23, 32, 15, 50, 10, 31, 58, 3, 45, 35, 27, 43, 5, 49, 33, 9, 42, 19, 29, 28, 14,39, 12, 38, 41, 13, 37, 48, 7, 16, 24, 55, 40, 61, 26, 17, 0, 1, 60, 51, 30, 4, 22, 25, 54, 21, 56,59, 6, 63, 57, 62, 11, 36, 20, 34, 44, 52]][:32])s = int(time.time())param["wts"] = "1684737775"h = []param = "&".join([f"{i[0]}={i[1]}" for i in sorted(param.items(), key=lambda x: x[0])])return hashlib.md5((param + c).encode(encoding='utf-8')).hexdigest(), s

生成w_rid的JS代码附上,  

 最后回到h5,B站播放量接口,构造完所有接口,获取响应结果跟网页返回的结果一致,基本上告一段落,最后当然还要需要代理IP加持,才能真正增加实际播放量!

有兴趣测试接口,或者获取完全完整算法的伙伴可以+q /+v  Api-hex 交流。

这篇关于最新版B站刷播放量接口协议参数(w_rid、aid、cid、buvid3、b_lsid、cookie),加密算法全流程解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/854691

相关文章

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速