现在如何知道在SHAKA PLAYER中通过Content Protection Callback?
How to know now to pass ContentProtectionCallback in SHAKA PLAYER?
任何人都可以帮助我知道现在通过 ContentProtectionCallback
以便我可以在 shaka 播放器
中处理 preProcessor
的 drm 许可证 url
[http://v1-6-2.shaka-player-demo.appspot.com/docs/tutorial-network.html][1]
var manifestUri =
'<mpd url>';
function initApp() {
// Install built-in polyfills to patch browser incompatibilities.
shaka.polyfill.installAll();
// Check to see if the browser supports the basic APIs Shaka needs.
if (shaka.Player.isBrowserSupported()) {
// Everything looks good!
initPlayer();
} else {
// This browser does not have the minimum set of APIs we need.
console.error('Browser not supported!');
}
}
function initPlayer() {
// Create a Player instance.
var video = document.getElementById('video');
var player = new shaka.Player(video);
player.configure({
drm: {
servers: {
'com.widevine.alpha': '<server url>',
}
}
});
// Attach player to the window to make it easy to access in the JS console.
window.player = player;
// Listen for error events.
player.addEventListener('error', onErrorEvent);
// Try to load a manifest.
// This is an asynchronous process.
player.load(manifestUri).then(function () {
// This runs if the asynchronous load is successful.
console.log('The video has now been loaded!');
}).catch(onError); // onError is executed if the asynchronous load fails.
}
function onErrorEvent(event) {
// Extract the shaka.util.Error object from the event.
onError(event.detail);
}
function onError(error) {
// Log the error.
console.error('Error code', error.code, 'object', error);
}
document.addEventListener('DOMContentLoaded', initApp);
[1]: http://v1-6-2.shaka-player-demo.appspot.com/docs/tutorial-network.html
请阅读这篇文章tutorial。在此页面中,解释了如何在请求之前或之后处理许可证。我假设 ContentProtectionCallback 是一个处理程序,用于在向服务器发出许可请求之前对其进行操作。对于这种情况:
player.getNetworkingEngine().registerRequestFilter(function(type, request) {
// Manipulate request before is sent.
if (type == shaka.net.NetworkingEngine.RequestType.LICENSE) {
const body = request.body;
// Do something with the body. Then, assign it back.
request.body = manipulateBody(body)
}
});
您也可以使用 registerResponseFilter
方法对响应应用相同的过程
任何人都可以帮助我知道现在通过 ContentProtectionCallback
以便我可以在 shaka 播放器
preProcessor
的 drm 许可证 url
[http://v1-6-2.shaka-player-demo.appspot.com/docs/tutorial-network.html][1]
var manifestUri =
'<mpd url>';
function initApp() {
// Install built-in polyfills to patch browser incompatibilities.
shaka.polyfill.installAll();
// Check to see if the browser supports the basic APIs Shaka needs.
if (shaka.Player.isBrowserSupported()) {
// Everything looks good!
initPlayer();
} else {
// This browser does not have the minimum set of APIs we need.
console.error('Browser not supported!');
}
}
function initPlayer() {
// Create a Player instance.
var video = document.getElementById('video');
var player = new shaka.Player(video);
player.configure({
drm: {
servers: {
'com.widevine.alpha': '<server url>',
}
}
});
// Attach player to the window to make it easy to access in the JS console.
window.player = player;
// Listen for error events.
player.addEventListener('error', onErrorEvent);
// Try to load a manifest.
// This is an asynchronous process.
player.load(manifestUri).then(function () {
// This runs if the asynchronous load is successful.
console.log('The video has now been loaded!');
}).catch(onError); // onError is executed if the asynchronous load fails.
}
function onErrorEvent(event) {
// Extract the shaka.util.Error object from the event.
onError(event.detail);
}
function onError(error) {
// Log the error.
console.error('Error code', error.code, 'object', error);
}
document.addEventListener('DOMContentLoaded', initApp);
[1]: http://v1-6-2.shaka-player-demo.appspot.com/docs/tutorial-network.html
请阅读这篇文章tutorial。在此页面中,解释了如何在请求之前或之后处理许可证。我假设 ContentProtectionCallback 是一个处理程序,用于在向服务器发出许可请求之前对其进行操作。对于这种情况:
player.getNetworkingEngine().registerRequestFilter(function(type, request) {
// Manipulate request before is sent.
if (type == shaka.net.NetworkingEngine.RequestType.LICENSE) {
const body = request.body;
// Do something with the body. Then, assign it back.
request.body = manipulateBody(body)
}
});
您也可以使用 registerResponseFilter
方法对响应应用相同的过程