gpt4 book ai didi

javascript - 如何使用 DOWNstream For Electron 保护离线内容的播放?

转载 作者:行者123 更新时间:2023-11-29 20:50:34 35 4
gpt4 key购买 nike

我正在尝试在 Electron 中保护离线内容的播放。

我正在尝试使用: https://github.com/castlabs/downstream_electron

连同他们与 Widevine 兼容的 Electron 版本:https://github.com/castlabs/electron-releases/releases/tag/v1.8.7-hdcp-vmp1010

根据 downstream_electron 的 README.md,“允许在 Electron 中 protected 地播放离线内容”。

我有一个概念验证设置 dashjs我可以在其中提取 session 信息并下载受 drm 保护的 dash list 以及音频和视频片段。

我正在使用 ezdrm 的公开资源:
list :http://wvm.ezdrm.com/demo/stream.mpd
许可证服务器:http://widevine-dash.ezdrm.com/proxy?pX=BF9CEB

当我调用 DownstreamElectronFE.downloads.getOfflineLink()下载 Assets 后,它返回给我:

{ 
offlineLink:"http://127.0.0.1:3010/movies/6441406178546155520/stream.mpd"
persistent:"F75D9FC450010B582A7951ED228DAF85"
}

因此,我从本地服务器获得了受 drm 保护的本地 list 。我如何获得“在 Electron 中 protected 地播放离线内容”?

如果我要提供这个 offlineLink 值作为 dash 视频播放器的源,它仍然需要连接到 internet 才能与许可服务器对话,所以它不会真正离线。

我的部分演示如下:

const dashjs = require('dashjs');

let session

function FakePersistentPlugin() {
this.createPersistentSession = (persistentConfig) => {
console.log('create - call of fake persistent plugin, persistentConfig', persistentConfig);
return new Promise((resolve) => {
setTimeout(function () {
console.log('resolving session',session.sessionId)
resolve(session.sessionId);
}, 5000);
});
};
this.removePersistentSession = (sessionId) => {
console.log('remove - call of fake persistent plugin, sessionId', sessionId);
return new Promise((resolve) => {
setTimeout(() => {
console.log('remove - call of fake persistent plugin resolved', sessionId);
resolve();
}, 5000);
});
};
}

const downstreamElectron = require("downstream-electron/dist").init(window,new FakePersistentPlugin());
console.log('downstreamElectron is ',downstreamElectron);


var player = dashjs.MediaPlayer().create();
player.setProtectionData({'com.widevine.alpha':{serverURL:'http://widevine-dash.ezdrm.com/proxy?pX=BF9CEB'}});
player.initialize(document.querySelector("#videoPlayer"))
player.attachSource('http://wvm.ezdrm.com/demo/stream.mpd')
player.play()

player.on( dashjs.MediaPlayer.events.KEY_SESSION_CREATED, (e) => {
session = e.data.session;
console.log('session is ',session)
});

const config = {
licenseUrl:'http://widevine-dash.ezdrm.com/proxy?pX=BF9CEB',
serverCertificate: new Uint8Array([0])
}

let manifestId
let persistId

function onProgress (err, stats) {
if (err) {
console.logs('on progress err', err, stats);
}
console.log('on progress ',stats);
};

function onFinish (err, info) {
if (err) {
console.log("onFinish error", err);
} else {
console.log("onFinish success", info);
downstreamElectron.downloads.getOfflineLink(info.manifestInfo.id)
.then(
function onSuccess(result) {console.log("offlineLink success", result)},
function onError(err) {console.log("error", err)
})
}
};



downstreamElectron.downloads.create('http://wvm.ezdrm.com/demo/stream.mpd')
.then(
function onSuccess(result) {
console.log("create success", result)
manifestId = result.id
downstreamElectron.downloads.createPersistent(manifestId,config)
.then(
(result)=>{
console.log("createPersistent success",result)
persistId = result

downstreamElectron.downloads.savePersistent(manifestId,persistId)
.then(
() => {
console.log('savePersistent success')

downstreamElectron.downloads.start(manifestId,{video:['video/avc1'],audio:['audio/und/mp4a']})
.then(
function onSuccess() {console.log("start success")},
function onError(err) {console.log("start error", err)
})

downstreamElectron.downloads.subscribe(manifestId, 1000, onProgress, onFinish)
.then(
function onSuccess() {console.log("subscribed successfully")},
function onError(err) {console.log("subscribe error", err)
})
},
(err) => {
console.log('savePersistent error',err)
}
)
},
(err)=>{
console.log("createPersistent error",err)
}
)
},
function onError(err) {console.log("create error", err)}
)

最佳答案

需要提前申请license,具体申请允许持久化(离线使用)的license。基本上,您需要在离线之前触发许可请求。某处可能有一个函数调用来执行此操作,否则您可以开始播放以获取许可证,然后再终止它。

请注意,颁发的许可证必须允许离线使用,这不是默认设置。 EZDRM 演示内容可能允许您申请这样的许可证,但它不太可能默认为您提供这样的许可证。

关于javascript - 如何使用 DOWNstream For Electron 保护离线内容的播放?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52122955/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com