最新版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

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱