使用 Widevine CDM 插件

在 Electron,你可以使用 Widevine CDM 插件装载 Chrome 浏览器。

获取插件

Electron 没有为 Widevine CDM 插件配置许可 reasons,为了获得它,首先需要安装官方的 Chrome 浏览器,这匹配了体系架构和 Electron 构建使用的 Chrome 版本。

注意: Chrome 浏览器的主要版本必须和 Electron 使用的版本一样,否则插件不会有效,虽然 navigator.plugins 会显示你已经安装了它。

Windows & macOS

在 Chrome 浏览器中打开 chrome://components/ ,找到 WidevineCdm 并且确定它更新到最新版本,然后你可以从 APP_DATA/Google/Chrome/WidevineCDM/VERSION/_platform_specific/PLATFORM_ARCH/ 路径找到所有的插件二进制文件。

APP_DATA 是系统存放数据的地方,在 Windows 上它是 %LOCALAPPDATA%,在 macOS 上它是 ~/Library/Application Support. VERSION 是 Widevine CDM 插件的版本字符串,类似 1.4.8.866. PLATFORMmacwin. ARCHx86x64

在 Windows,必要的二进制文件是 widevinecdm.dll and widevinecdmadapter.dll,在 macOS,它们是 libwidevinecdm.dylibwidevinecdmadapter.plugin。你可以将它们复制到任何你喜欢的地方,但是它们必须要放在一起。

Linux

在 Linux,Chrome 浏览器将插件的二进制文件装载在一起,你可以在 /opt/google/chrome 下找到,文件名是 libwidevinecdm.solibwidevinecdmadapter.so

使用插件

在获得了插件文件后,你可以使用 --widevine-cdm-path 命令行开关来将 widevinecdmadapter 的路径传递给 Electron ,插件版本使用 --widevine-cdm-version 开关.

注意: 虽然只有 widevinecdmadapter 的二进制文件传递给了 Electron,widevinecdm 二进制文件应当放在它的旁边。

必须在 app 模块的 ready 事件触发之前使用命令行开关,并且 page 使用的插件必须激活。

示例代码:

  1. const {app, BrowserWindow} = require('electron')
  2. // 你必须通过 `widevinecdmadapter` 文件名,它是
  3. // * `widevinecdmadapter.plugin` on macOS,
  4. // * `libwidevinecdmadapter.so` on Linux,
  5. // * `widevinecdmadapter.dll` on Windows。
  6. app.commandLine.appendSwitch('widevine-cdm-path', '/path/to/widevinecdmadapter.plugin')
  7. // 插件版本可以从 Chrome 浏览器的 `chrome://plugins` 页面获得。
  8. app.commandLine.appendSwitch('widevine-cdm-version', '1.4.8.866')
  9. let win = null
  10. app.on('ready', () => {
  11. win = new BrowserWindow({
  12. webPreferences: {
  13. // 这个 `plugins` 必须启用。
  14. plugins: true
  15. }
  16. })
  17. win.show()
  18. })

验证插件

为了验证插件是否工作,你可以使用下面的方法: