如何解密AES-128加密的m3u8视频文件?

dab*_*boo 5 encryption openssl aes m3u8

我试图解密AES-128加密的m3u8视频文件,例如:

m3u8文件:

#EXTM3U
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-ALLOW-CACHE:NO
#EXT-X-VERSION:2
#EXT-X-FAXS-CM:MII6lAYJKoZIhvcNAQcCoII6hTCCOoECAQExCzAJBgUrDgMCGgUAM... very long key...
#EXT-X-KEY:METHOD=AES-128,URI="faxs://faxs.adobe.com",IV=0X99b74007b6254e4bd1c6e03631cad15b
#EXT-X-TARGETDURATION:8
#EXTINF:8,
video.mp4Frag1Num0.ts
#EXTINF:8,
video.mp4Frag1Num1.ts
...
Run Code Online (Sandbox Code Playgroud)

我试过openssl:

openssl aes-128-cbc -d -kfile key.txt -iv 99b74007b6254e4bd1c6e03631cad15b -nosalt -in video_enc.ts -out video_dec.ts
Run Code Online (Sandbox Code Playgroud)

key.txt包含很长的键 - >

bad decrypt
1074529488:error:06065064:digital envelope routines:EVP_DecryptFinal_ex:bad decrypt:evp_enc.c:539:
Run Code Online (Sandbox Code Playgroud)

我究竟做错了什么 ?

sal*_*ter 7

这可能有点麻烦,但是给定一个 .m3u8 文件的 URL,它将下载和解密构成流的文件:

#!/usr/bin/env bash
curl "$1" -s | awk 'BEGIN {c=0} $0 ~ "EXT-X-KEY" {urlpos=index($0,"URI=")+5; ivpos=index($0,"IV="); keyurl=substr($0, urlpos, ivpos-urlpos-2); iv=substr($0, ivpos+5); print "key=`curl -s '\''"keyurl"'\'' | hexdump -C | head -1 | sed \"s/00000000//;s/|.*//;s/ //g\"`"; print "iv="iv} $0 !~ "-KEY" && $0 ~ "http" {printf("curl -s '\''"$0"'\'' | openssl aes-128-cbc -K $key -iv $iv -d >seg%05i.ts\n", c++)}' | bash
Run Code Online (Sandbox Code Playgroud)

此脚本生成第二个脚本,用于提取密钥和初始化向量,并在下载时使用它们进行解密。它需要 curl、awk、hexdump、sed 和 openssl 才能运行。它可能会在未加密的流或使用 AES-128 以外的流(是否支持任何其他加密?)上阻塞。

您会得到一堆文件:seg00000.ts、seg00001.ts 等。使用 tsMuxeR ( https://www.videohelp.com/software/tsMuxeR ) 将它们合并为一个文件(简单的串联不起作用)对我来说......这是我首先尝试的):

(echo "MUXOPT --no-pcr-on-video-pid --new-audio-pes --vbr  --vbv-len=500"; (echo -n "V_MPEG4/ISO/AVC, "; for i in seg*.ts; do echo -n "\"$i\"+"; done; echo ", fps=30, insertSEI, contSPS, track=258") | sed "s/+,/,/"; (echo -n "A_AAC, "; for i in seg*.ts; do echo -n "\"$i\"+"; done; echo ", track=257") | sed "s/+,/,/") >video.meta
tsMuxeR video.meta video.ts
Run Code Online (Sandbox Code Playgroud)

(轨道 ID 和帧率可能需要调整...通过将下载的文件之一传递给 tsMuxeR 来获取要使用的值。)

然后使用 ffmpeg 重新混合到更广泛理解的东西:

ffmpeg -i video.ts -vcodec copy -acodec copy video.m4v
Run Code Online (Sandbox Code Playgroud)

  • 感谢您的回复,上周我可以使用 hlsdl 下载视频,https://github.com/selsta/hlsdl (2认同)

Nik*_*lai 6

为了解密加密的视频流,您需要加密密钥。此密钥不是流的一部分。它应该单独获得。

EXT-X-FAXS-CM 标头包含 DRM 元数据而不是密钥。

这是来自 Adob​​e Media Server 开发人员指南的 excert:受 Adob​​e Access Server 保护的变体播放列表还需要包含 #EXT-X-FAXS-CM 标签。变体播放列表中#EXT-X-FAXS-CM 标签的值是引用单个流之一的DRM 元数据的相对URI。在客户端,变体播放列表中的#EXT-X-FAXS-CM 标签将是用于创建 DRM 会话。相同的 DRM 会话将用于变体播放列表中的所有加密 M3U8 文件。

完整指南可在此处找到:http : //help.adobe.com/en_US/adobemediaserver/devguide/WS5262178513756206-4b6aabd1378392bb59-7fe8.html

还提到 faxs://faxs.adobe.com URI 用于本地密钥服务。所以从设备本地获得的密钥。