如何为html5视频加载vtt文件启用CORS?

时间:2017-08-27 06:32:57

标签: html5-video webvtt vtt

我的需要

html5视频元素加载保存在不同域中的视频和vtt文件。

问题

未加载vtt且错误Text track from origin has been blocked from loading: Not at same origin as the document, and parent of track element does not have a 'crossorigin' attribute.

我的调查

我知道需要使用CORS,因此可以在html5中成功加载vtt。

我已在服务器端为来自任何域的请求启用了CORS。

有些文章称将crossorigincrossorigin="anonymous"添加到`元素中可以完成这项工作,但它不起作用。视频未加载或出现不同的错误

我已将我的代码放在下面

<body>
  <div class="container">
    <video id="myvideo" controls preload="auto" width="640" height="264" autoplay>
      <source src=http://video.dublearn.net/-KqIgE-3roMSBbiHUmLI/video.mp4 type="video/mp4"></source>
      <track kind="captions" label="English" srclang="en" src=http://video.dublearn.net/-KqIgE-3roMSBbiHUmLI/video.vtt default>
    </video>
</body>

2 个答案:

答案 0 :(得分:1)

希望这可以帮助下一个人偶然发现这个SO问题。我发现IE(10和11)即使启用了CORS,也不支持为<track>加载跨域VTT文件。为了增加IE对字幕的支持,我不得不使用下面的脚本。

此脚本通过AJAX下载每个VTT文件,创建一个blob URL,并将每个<track> src替换为其各自的blob URL。

window.addEventListener("load", function() {
  if (window.navigator.userAgent.indexOf("MSIE ") < 0 && window.navigator.userAgent.indexOf("Trident/") < 0) {
    // Not IE, do nothing.
    return;
  }

  var tracks = document.querySelectorAll("track")

  for (var i = 0; i < tracks.length; i++) {
    loadTrackWithAjax(tracks[i]);
  }
});

function loadTrackWithAjax(track) {
  var xhttp = new XMLHttpRequest();

  xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200 && this.responseText) {
      // If VTT fetch succeeded, replace the src with a BLOB URL.
      var blob = new Blob([this.responseText], { type: 'text/vtt' });
      track.setAttribute("src", URL.createObjectURL(blob));
    }
  };
  xhttp.open("GET", track.src, true);
  xhttp.send();
}
<video controls preload width="600" height="337.5" autoplay crossorigin="anonymous">
      <source src="https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-576p.mp4" type="video/mp4"></source>
      <track kind="captions" label="English" srclang="en" src="https://cdn.plyr.io/static/demo/View_From_A_Blue_Moon_Trailer-HD.en.vtt" default>
</video>

答案 1 :(得分:0)

我可以确认crossorigin=anonymous元素上的video属性确实按预期加载了文本轨道。

给这一点。

<video id="myvideo" controls preload="auto" width="640" height="264" autoplay crossorigin="anomymous"> <source src=http://video.dublearn.net/-KqIgE-3roMSBbiHUmLI/video.mp4 type="video/mp4"></source> <track kind="captions" label="English" srclang="en" src=http://video.dublearn.net/-KqIgE-3roMSBbiHUmLI/video.vtt default> </video>

最后,请记住,您必须使用Web服务器来提供此剪辑的HTML - 这不能在本地完成(即。​​file//)。

如果您熟悉node - 安装http-server,请使用--cors并使用ngrok。