存在 OSS 上的 mp4 文件如何加密(禁止下载)

2022 年 3 月 2 日
 jiobanma

需求是存在 OSS 上的一些 mp4 文件,只能通过 web 系统内的播放器播放,但是不能通过 F12 这种方式扒到的播放器标签存的 src 里面的原文件地址单独拿出去下载.也就是说即使拿到源文件地址也不能正常预览.

有大佬知道好的实现思路吗?

5281 次点击
所在节点    程序员
29 条回复
009694
2022 年 3 月 2 日
不让下载 那还可以录屏
jiobanma
2022 年 3 月 2 日
@009694 当然不可能堵住所有的口子,只能说是防君子不防小人,能加点门槛就加点
Yanickkk
2022 年 3 月 2 日
本地解码的时候解密嘛,有点像优酷之类的,下载下来的视频都是需要解密的,但是录屏就防不住,还有模拟输出设备的录屏就更没戏了,
jiobanma
2022 年 3 月 2 日
@yannxia 因为只是一个简单的播放,就是前端一个播放器直接拿到源文件的地址去播放,所以增加视频编解码的话成本太高了
tieqishan07li
2022 年 3 月 2 日
设置防盗链、使用 STS Token 拿资源
vone
2022 年 3 月 2 日
wu67
2022 年 3 月 2 日
换成 m3u 咯, 让播放器自己加载. 然后再整点 token, 定期刷新.
gadfly3173
2022 年 3 月 2 日
私有 bucket + sts token 或自行实现前置访问认证,sts 应该是成本最低的方案了,不过用户稍稍看下请求也是能当场下下来的
jiobanma
2022 年 3 月 2 日
@wu67 m38u 的话 得加一道流媒体服务了吧
Qusic
2022 年 3 月 2 日
m3u8 做 streaming ?这样视频分片存储,一方面拖进度条的用户体验会很大提升,另一方面大部分用户都不知道怎么转码合并视频吧,我猜。另外把分片的视频流放前端 blob 里那难度就更大了
jiobanma
2022 年 3 月 2 日
@Qusic 提供给我们的视频就是一个 mp4 格式的,如果切片的话,还要有个流媒体服务去切片放到 oss 里 那成本有点高了
jiobanma
2022 年 3 月 2 日
@vone 这得二开播放器了吧
cssk
2022 年 3 月 2 日
token ,header
ntdll
2022 年 3 月 2 日
不嫌麻烦就是 hls + aes ,前端自行获取密钥,通过 ffmpeg wasm 播放。

再简化一点的方案,blob url 就足够挡住多数 F12 的初级用户了。
windyskr
2022 年 3 月 2 日
wu67
2022 年 3 月 2 日
@jiobanma 各种云应该有相应的服务吧. 考虑一下用现成的咯, 干嘛自己肝.
misdake
2022 年 3 月 2 日
可能对楼主的问题没啥帮助,只是沿着 m3u8 的路提一句今天的小发现
今天下 wordpress 一个视频的时候,发现是静态 m3u8+静态单视频文件。视频文件可能是根据关键帧切分的,在拼接的时候直接二进制拼接,两端和切片之间都夹杂脏数据,m3u8 用#EXT-X-BYTERANGE 指向视频的一段段数据。这样直接下载文件是放不出来的。
但是,m3u8 没有任何保护,直接用 m3u8 下载就行了。。。
liuidetmks
2022 年 3 月 2 日
添加 DRM ?
LnTrx
2022 年 3 月 2 日
楼主先明确一下,blob url 这种程度够不够?
shellc
2022 年 3 月 2 日
楼上有提到使用阿里云的视频加密方案,这个方案需要使用阿里云的播放器,同时如果能接受视频云的计费方式是可以的。

如果你的需求只是为了解决 Web 播放视频,并阻止通过查看网页源代码获取 URL 下载,并且不考虑爬虫的话。有一个方案你可以考虑。这个方案的核心就是 OSS 的 URL 是一次性的。可以把 bucket 或文件设置为 private 可见,在网页中输出的视频地址通过 OSS 的签名来访问,签名设置有效期为 10 秒,只要视频播放器在 10 秒内开始访问 OSS ,视频就可以顺利播放。超过 10 秒后,这个 URL 过期。10 秒是个经验值,就是浏览器从提交请求,到播放器开始访问 OSS 的超时时间。

绕过的方法就是写脚本自动化爬取,直接访问页面拿到地址开始下载。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://v2ex.xtra.eu.org/t/837508

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX