媒体资源加密-and-解密获取
各类平台网页中的视频通常会被
加密处理
以防止别人拿走; 防盗技术还是有很多种的:[3]- FFmpeg-HLS-AES_128_CBC 加密
- url 中加入 token 验证
- 验证用户身份再给链接(session,cookie)
- 视频加水印
- 限制跨域访问
- …etc
下面只摸一下技术层面的 1.和2.
token-防盗链
如 http://xxxxxx.com/m3u8/hunan/desc.m3u8?stream_id=hunan<m=1410595018&lkey=8bc1e0fe35f6321ef560f8ccffb70e5d&path=59.49.42.14,58.59.3.9,58.59.3.51&platid=10&splatid=1015&tag=live&cips=127.0.0.1&ext=m3u8&sign=live_tv
[8]
在 url 加上 时间戳,ip 地址,平台 id,splatid,tag,cips,ext,sign 等参数, 可以让服务器鉴别是否被其他网站/客户端请求, 并作出 403 响应
同一参数的 url 无法被复用, 但是仍可以通过动态调整参数来绕过服务器的检测
FFmpeg-HLS-AES_128_CBC
这么一坨 💩,什么意思嘛?
FFmpeg 是最强大的视频编解码器, 可以把输入的视频处理成符合 HLS 规范的流媒体, 同时通过 AES-128-CBC 格式的秘钥加密视频
浅入深出,别急慢慢吃… 下面结合这个库动动手就明白了:[4]
分片
分片的方式比较简单,这里我们准备好一个
demo.mp4
, 丢给 FFmpeg 下面的命令ffmpeg -i demo.mp4 -codec copy -f segment -segment_list index.m3u8 -segment_time 30 %d.ts
执行完会出来下面这些东西,这些 ts 文件就是分成片的小段视频,此处没加密可以直接播放
有些播放器支持的话 index.m3u8 也是可以播放的, 其实就是引用的这些 ts
上面命令中
index.m3u8
这个文件是分片的索引文件, 指明了 ts 文件的先后顺序,时长,版本和加密等信息- TS: MPEG2-Transport Stream,高清相机拍摄视频的封装格式;特点就是要求从视频流的任一片段开始都是可以独立解码的
- m3u8: HTTP Live Streaming(HLS) 协议格式的基础,Unicode 版本的 M3U,此文件用 UTF-8 编码[1]
下图 index 就是 m3u8,作用就是索引 ts
喏,index.m3u8 文件内容应该能看懂
#EXTM3U
#EXT-X-VERSION:3
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-ALLOW-CACHE:YES
#EXT-X-TARGETDURATION:32
#EXTINF:30.720000,
0.ts
#EXTINF:29.280000,
1.ts
#EXTINF:31.880000,
2.ts
#EXTINF:29.040000,
3.ts
#EXTINF:29.320000,
4.ts
#EXTINF:6.280000,
5.ts
#EXT-X-ENDLIST
分片作用-引子
分段加载视频而不是一口气加载到底
大部分视频用户不会完完整整的看,分段加载减轻服务器压力,也使用户体验好
(好几 G 的电影,一口气加载到底, 内存/缓存遭不住…)
分片可以让用户无法
直接通过链接
在浏览器获取完整的 mp4 视频
但,可以通过获取所有 ts 文件合并为 mp4
插件市场的一些插件可以通过 .m3u8 获取并合并.ts 间接获取完整的 .MP4
于是为了反破解出现了 某些花活
和 视频加密
花活
把 .m3u8 文件伪装成 .mp4, 可以让大部分没有伪装识别能力的爬虫找不着北 (比如 CoCocut)
m3u8 中多层嵌套 m3u8 (套娃), 有些爬虫是支持的, 有的 G 了
#EXTM3U
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=1064000
1000kbps.m3u8
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=564000
500kbps.m3u8
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=282000
250kbps.m3u8
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=2128000
2000kbps.m3u8…etc
加解密流程图
原创哦,转载请标记
openssl-手动加密
encrypt-without-iv
此处通过 shell 脚本分析,墙裂建议结合仓库学习:[4]
workPath="2.encrypted-without-iv" |
如图,加密后的 ts 就不能直接播放了
encrypt-with-iv
这个 iv (initialisation vector,初始化向量) 有点迷, 作用是增强随机性
workPath="3.encrypted-with-iv" |
FFmpeg-分片加密一条龙
workPath="4.encrypt-with-FFmpeg" |
index.m3u8
可见生成的没什么问题,而且可以通过下面的方法正常解密
#EXTM3U
#EXT-X-VERSION:3
#EXT-X-TARGETDURATION:32
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-PLAYLIST-TYPE:VOD
#EXT-X-KEY:METHOD=AES-128,URI="./enc.key",IV=0x2b5cc8a84648ed8ce5f64e5845d3cb7c
#EXTINF:30.720000,
enc_0.ts
#EXTINF:29.280000,
enc_1.ts
#EXTINF:31.880000,
enc_2.ts
#EXTINF:29.040000,
enc_3.ts
#EXTINF:29.320000,
enc_4.ts
#EXTINF:6.280000,
enc_5.ts
#EXT-X-ENDLIST
解密-合并
上面加密会了的话,解密就简单了,完全就是反过来
合并方法取自: [6]
这篇文章[5]简单介绍了下如何手动解密,其文中把 key 和 iv 位数标错为 16 了,别误解
inputPath="2.encrypted-without-iv" |
如图
dec_*.ts
为解密后的文件,可以直接播放了可以看项目中的
5.
, 合并后的 mp4 也没有问题但 原视频 != 分片加解密合并后的视频, 大小差不多但是会有差异 (9.87MB vs 9.95MB)
获取
下面就是对资源获取方式的 推荐
了
视频
CoCocut: 这个插件官方直接说了不支持爬加密视频,但是大部分平台用起来
还是很棒的,插件中最棒的
有个小弊病, 它不开会员的话是超慢的单线程下载… 我常用它获取 m3u8 地址让下面这伙计下载
N_m3u8DL-CLI: 这家伙可以通过 m3u8 下载加密视频; 支持多线程,很快
可以手动破解加密视频 [7]
QQ 浏览器手机 app, 直接进对应网页就可以爬下来视频,加密的也可以,速度拉满 (小母牛倒立 🐄🍺
网页图片
下面两个差不多,都是把页面现有的图片都扒下来,
按域名分类
,很容易筛选出来这方法并不适用于获取视频.
梦想资源下载器
网页右键另存为
Picviewer CE+
QQ-群图片
经常有老哥在群里发图,苦于一张张保存手抽筋,发现了此方法:
打开电脑版消息管理器,找到那些聊天记录
选择,复制
发送给
我的手机
然后就无了, 这手段对于保存好几十/上百张图十分便利
借物表
[2]: https://github.com/fftt2017/hls-m3u8-sample
[4]: https://github.com/Weidows-projects/hls-m3u8-sample, 此库是在[2]的基础上改进的