在浏览视频网站时,你是否遇到过截屏或录屏时画面变黑的情况?单纯依靠 JS 监听快捷键往往难以奏效,因为用户完全可以绕过前端逻辑。真正能实现这一效果的,是浏览器原生支持的 Encrypted Media Extensions(EME)。

什么是 EME
Encrypted Media Extensions 是 W3C 定义的一套 Web API,用于让浏览器播放受 DRM(数字版权管理)加密的媒体内容。通俗来说,EME 是一套 JavaScript API,用来控制浏览器的 DRM 解密模块。
更多详细信息可参考官方文档:https://www.w3.org/TR/encrypted-media/
常见 DRM 方案:
| 平台 | DRM |
|---|---|
| Chrome、Android | Google Widevine |
| Edge/Windows | Microsoft PlayReady |
| Safari/iOS/macOS | Apple FairPlay |
EME 如何实现防截屏 / 防录屏
在浏览器层面,EME 配合 DRM 可以实现防截屏和防录屏,其核心机制如下:
- 媒体文件加密:内容本身是加密视频(如 Widevine Modular 加密),无法直接播放。
- CDM 模块解密:浏览器内置一个 CDM(Content Decryption Module),例如 Chrome 内置 Widevine CDM。CDM 运行在沙箱中,不暴露密钥。
- 禁止系统级截屏:取决于 DRM 等级。例如在 Chrome 上播放 Netflix 时,使用系统截图键或屏幕录制,视频区域会显示为黑色。
- Widevine L1(硬件级)支持防截屏。
- DRM 解密后的视频帧不会进入 CPU 层,而是直接通过 GPU 的保护路径输出。
- 截屏 API 无法捕获受保护的视频帧。
- 禁止扩展抓取:DRM 视频帧在受保护的视频管线(Video Pipeline)中,浏览器扩展无法获取。
- 禁止调试工具记录:媒体解密密钥不会暴露在 JS 中。
EME 播放加密媒体的代码示例
我们知道 EME 是一套 W3C 标准化的 JavaScript API,它在不暴露密钥和明文数据的前提下,充当网页应用、浏览器和底层 DRM 系统(CDM)之间的'安全信使'。以下示例展示一个使用 EME 播放加密 DASH(mpd)视频的完整流程。
注意:需要服务器提供 License Server 才能真正播放。


