iOS 设备上的 Azure 媒体播放器



我正在使用 Azure 媒体播放器在必须仅在移动设备中使用的 Web 应用中流式传输 O365 视频。它适用于WP和Android,但播放器停留在iOS上。

这是我的代码

client.DefaultRequestHeaders.Add("Authorization", "Bearer " + bearer);
            client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
            var response = await client.GetAsync($"{url}/GetPlaybackUrl('1')");
            var content = await response.Content.ReadAsStringAsync();
            var firstVal = JsonConvert.DeserializeObject<VideoToken>(content);
            response = await client.GetAsync($"{url}/GetStreamingKeyAccessToken");
            content = await response.Content.ReadAsStringAsync();
            var secondVal = JsonConvert.DeserializeObject<VideoToken>(content);

客户端

<video id="newsVideoAMP" class="azuremediaplayer amp-default-skin amp-big-play-centered" tabindex="0"></video>
var initVideoPlayer = function (playbackUrl, streamingKeyAccessToken) {
    try {
        var myOptions = {
            "nativeControlsForTouch": false,
            controls: true,
            autoplay: false,
            techOrder: ["azureHtml5JS", "flashSS", "html5FairPlayHLS", "silverlightSS", "html5"],
            logo: { enabled: false }
        }
        newsVideoPlayer = amp("newsVideoAMP", myOptions,
            function () {
                this.addEventListener(amp.eventName.error, function () {
                    window.alert('error');
                    console.log('Error: amp init');
                    var errorDetails = newsVideoPlayer.error();
                    window.alert(errorDetails);
                    var code = errorDetails.code;
                    var message = errorDetails.message;
                    $("#log").append("<li><span>code: " + code + " - detail: " + message + "</span></li>')");
                });
            });
        newsVideoPlayer.src([
            {
                "src": playbackUrl,
                "type": "application/vnd.ms-sstr+xml",
                "protectionInfo": [
                    {
                        "type": "AES",
                        "authenticationToken": streamingKeyAccessToken
                    }
                ]
            }]);
    }
    catch (err) {
        console.log(err);
    }
}

我认为这个问题与视频编码有关。所以我尝试使用GetPlaybackUrl('0')(并避免下一个令牌请求(,但播放器停止在 WP 和 Android 上工作,仍然无法在 iOS 上运行。

回调函数中的记录器没有告诉我一些有用的东西,我也尝试更改技术顺序。

是否有控制台来管理视频编码以避免AES算法和解密令牌?因为这个文档解释了iOS与HTML5技术一起工作,所以不会有令牌请求。我该如何解决?谢谢

我找到了在iOS设备上复制视频的解决方法。我没有使用REST API,而是在我的页面中放置了一个嵌入视频的iframe元素。像这样(使用 MVC Razor(:

var url = "{YourWebsiteUrl}/portals/hub/_layouts/15/VideoEmbedHost.aspx?chId={YourChannelId}&vId={YourVideoId}&width=853&height=480&autoPlay=false&showInfo=false";
<iframe width=853 height=480 id="videoframe" src="@url" allowfullscreen data-spresponsive style='position: absolute; top: 0; left: 0; right: 0; bottom: 0; height: 100%; max-width: 100%;'></iframe>

我从Office365视频视频页面中的"嵌入"菜单弹出窗口中获取此代码。

如果其他人知道另一种(更好的(方法,请告诉我。谢谢

最新更新