从 .NET Core 将视频流式传输到 Safari

Ale*_*mer 5 safari video-streaming asp.net-core range-header

流式传输在除 Safari 之外的所有浏览器中都能正常运行。据我所知,请求应该支持范围标头。

这是我正在使用的代码:

    public async Task<FileStreamResult> GetVideoStream()
        {
            if (Request.Headers.ContainsKey("Range"))
            {
                Request.Headers.TryGetValue("Range", out var range);
                _httpClient.DefaultRequestHeaders.Add("Range", range.ToString());
            }

            var stream = await _httpClient.GetStreamAsync(_url);

            return File(stream, "video/mp4", true);
        }
Run Code Online (Sandbox Code Playgroud)

要求:

curl --range 0-99 https://localhost:44312/GetVideoStream -o D:\test
Run Code Online (Sandbox Code Playgroud)

运行良好,仅保存 100 字节到文件。

还尝试了各种控件静音playsinline preload =“metadata”type =“video / mp4”

Ale*_*mer 1

最后,我能够强制 Safari 流式传输视频。需要设置“Content-Range”标头:

public async Task<FileStreamResult> GetVideoStream()
{
  if (Request.Headers.ContainsKey("Range"))
  {
      _httpClient.DefaultRequestHeaders.Remove("Range");
      var headersResponse = await _httpClient.GetAsync(_url, HttpCompletionOption.ResponseHeadersRead);

      Request.Headers.TryGetValue("Range", out var range);

      if (headersResponse.IsSuccessStatusCode && headersResponse.Content.Headers.GetValues("Content-Length").Any())
          HttpContext.Response.Headers.Add("Content-Range", $"{range[0].Replace("=", " ")}/{headersResponse.Content.Headers.GetValues("Content-Length").First()}");

      _httpClient.DefaultRequestHeaders.Add("Range", range.ToString());
  }

  var stream = await _httpClient.GetStreamAsync(_url);

  return File(stream, "video/mp4", true);
}
Run Code Online (Sandbox Code Playgroud)