Python爬虫:通过js逆向获取某瓜视频的下载链接

爬虫:通过js逆向获取某瓜视频的下载链接

    • [1. 前言](#1. 前言)
    • [2. 获取script标签下的视频加密数据](#2. 获取script标签下的视频加密数据)
    • [3. 第一步:获取解密后的视频下载链接](#3. 第一步:获取解密后的视频下载链接)
    • [4. 第二步:模拟生成加密的webid值](#4. 第二步:模拟生成加密的webid值)

1. 前言

就小编了解,某瓜视频这个网站对应视频下载链接加密处理至少经过三个版本。之前在CSDN发布了一篇关于它的视频下载链接获取方式,但是目前已经失效了,于是现在小编重新发布一篇。注意:内容仅供学习使用,切莫用于商业活动。另外,文章中只涉及到相关获取下载链接的过程,不提供相关代码哈!

2. 获取script标签下的视频加密数据

随便打开一个视频链接,然后在开发者工具下查找script标签,如下:

直接搜索

py 复制代码
//script[@id='SSR_HYDRATED_DATA']/text()

可以发现这里定义了一个js变量,类型为对象。而对应的视频下载链接加密数据就在这个对象数据里边。可以使用requests模块访问这个网页,然后使用xpath(其他方式比如bs4,re正则表达式)方式获取到这个对象数据,之后经过一些处理把这个js对象数据转化为python的字典数据,然后就可以找到对应的视频下载链接的加密数据了,如下:

这个main_url和backup_url_1键对应的值都是视频下载链接的加密数据,通过一定解密处理,最终可以得到的下载链接如下:

这时的这个下载链接不就是我们需要的吗?虽然还缺少几个参数。

此时还缺少参数_vid、webid、fid、wid,需要说明的是,_vid就是当前播放的视频id,可以从上述那个对象数据找到(不过好像也不是一定需要的),而fid、wid值是固定的,当然可能随着平台的不同,会有所差异。而webid的值是有两个值组成,用"-"隔开,"-"前面的值是固定的,当然可能随着平台的不同,会有所差异;而"-"后面的值是一个加密数据,需要用到上述经过解密处理的下载链接中的expires值(是一个长度为10的时间戳字符串),通过一定加密处理和参数拼接,即可获取到对应视频下载链接,如下:

下面用两步来说明一下获取对应视频下载链接的过程。

3. 第一步:获取解密后的视频下载链接

首先,在源代码/来源这里,打开控制台抽屉栏,然后在搜索输入框中输入 Hr=,找到这个Hr函数,然后在其下面这里打下断点。

之后刷新当前页面,然后对当前断点进行按步调式,可以发现,此时执行的代码块是这个。

可以看一下此时的arguments的值,如下:

可以发现,此时的backup_url_1和main_url的值都是看不懂字符串,但是把这个函数执行一遍,你就会发现,此时的back_url_1和main_url的值是一段链接字符串了,如下:

而这个n就是对应外部这个函数,如下:

通过多次执行后发现,这个e函数中其实也并没有执行解密操作,而是通过调用其他函数才实现的。

在上述这里打下断点,多次执行断点,最终可以获取到视频下载链接,由于涉及到比较多内容,小编不在此处详细说明了,读者可以自行尝试。

最后一步是执行base64decode函数。

4. 第二步:模拟生成加密的webid值

这里需要找到这个js包下这处,此处打下断点。

另外此处,也打下断点(因为webid加密处理在这里)

看看它的执行结果。

因为上述过程比较多,小编就不一一讲述了,读者有兴趣,可以自行尝试,需要注意的是其中一些数据来源开头讲到的那个对象数据喔!另外有一些数据是固定的。运行结果如下:

相关推荐
鸡吃丸子12 分钟前
Next.js 入门指南
开发语言·javascript·next.js
罚时大师月色26 分钟前
Vue+ts 如何实现父组件和子组件通信
javascript·vue.js·ecmascript
漂流瓶jz38 分钟前
快速定位源码问题:SourceMap的生成/使用/文件格式与历史
前端·javascript·前端工程化
fury_1231 小时前
vue3:数组的.includes方法怎么使用
前端·javascript·vue.js
宁&沉沦1 小时前
Cursor 科技感的登录页面提示词
前端·javascript·vue.js
Dragonir1 小时前
React+Three.js 实现 Apple 2025 热成像 logo
前端·javascript·html·three.js·页面特效
古一|2 小时前
Vue3中ref与reactive实战指南:使用场景与代码示例
开发语言·javascript·ecmascript
peachSoda72 小时前
封装一个不同跳转方式的通用方法(跳转外部链接,跳转其他小程序,跳转半屏小程序)
前端·javascript·微信小程序·小程序
熊猫钓鱼>_>3 小时前
TypeScript前端架构与开发技巧深度解析:从工程化到性能优化的完整实践
前端·javascript·typescript
JYeontu4 小时前
肉眼难以分辨 UI 是否对齐,写个插件来辅助
前端·javascript