如何使用 ASP.NET MVC 进行异步/等待视频流?
How to do async / await video streaming with ASP.NET MVC?
最近我读了这篇关于视频流的文章 (https://blogs.ibs.com/2017/01/24/streaming-video-content-to-a-browser-using-web-api)。
文章中提供的解决方案非常有效,但我想知道是否有任何 async / await 替代方案,因为文章仅显示围绕 HttpResponseMessage
构建的解决方案,我担心性能问题?
性能方面应该没有问题。
使用 async await 不会带来太大的改进。 FileStreamer
已经在访问文件流时利用异步操作。
如果你坚持使用async await,你可以考虑将action的主体包裹在一个Task.Run
中,让action return一个Task<HttpResponseMessage>
.
这里确实不需要过早的优化。
审查任何潜在的阻塞调用并相应地重构
例如
public async Task<IHttpActionResult> Get(string filename) {
var filePath = await GetFilePathAsync(filename);
if (!File.Exists(filePath))
return NotFound();
var response = getResponse(filePath);
return ResponseMessage(response);
}
private HttpResponseMessage getResponse(string filePath) {
var response = Request.CreateResponse();
response.Headers.AcceptRanges.Add("bytes");
var streamer = new FileStreamer();
streamer.FileInfo = new FileInfo(filePath);
response.Content = new PushStreamContent(streamer.WriteToStream, GetMimeType(filePath));
RangeHeaderValue rangeHeader = Request.Headers.Range;
if (rangeHeader != null) {
long totalLength = streamer.FileInfo.Length;
var range = rangeHeader.Ranges.First();
streamer.Start = range.From ?? 0;
streamer.End = range.To ?? totalLength - 1;
response.Content.Headers.ContentLength = streamer.End - streamer.Start + 1;
response.Content.Headers.ContentRange = new ContentRangeHeaderValue(streamer.Start, streamer.End,
totalLength);
response.StatusCode = HttpStatusCode.PartialContent;
} else {
response.StatusCode = HttpStatusCode.OK;
}
return response;
}
最近我读了这篇关于视频流的文章 (https://blogs.ibs.com/2017/01/24/streaming-video-content-to-a-browser-using-web-api)。
文章中提供的解决方案非常有效,但我想知道是否有任何 async / await 替代方案,因为文章仅显示围绕 HttpResponseMessage
构建的解决方案,我担心性能问题?
性能方面应该没有问题。
使用 async await 不会带来太大的改进。 FileStreamer
已经在访问文件流时利用异步操作。
如果你坚持使用async await,你可以考虑将action的主体包裹在一个Task.Run
中,让action return一个Task<HttpResponseMessage>
.
这里确实不需要过早的优化。
审查任何潜在的阻塞调用并相应地重构
例如
public async Task<IHttpActionResult> Get(string filename) {
var filePath = await GetFilePathAsync(filename);
if (!File.Exists(filePath))
return NotFound();
var response = getResponse(filePath);
return ResponseMessage(response);
}
private HttpResponseMessage getResponse(string filePath) {
var response = Request.CreateResponse();
response.Headers.AcceptRanges.Add("bytes");
var streamer = new FileStreamer();
streamer.FileInfo = new FileInfo(filePath);
response.Content = new PushStreamContent(streamer.WriteToStream, GetMimeType(filePath));
RangeHeaderValue rangeHeader = Request.Headers.Range;
if (rangeHeader != null) {
long totalLength = streamer.FileInfo.Length;
var range = rangeHeader.Ranges.First();
streamer.Start = range.From ?? 0;
streamer.End = range.To ?? totalLength - 1;
response.Content.Headers.ContentLength = streamer.End - streamer.Start + 1;
response.Content.Headers.ContentRange = new ContentRangeHeaderValue(streamer.Start, streamer.End,
totalLength);
response.StatusCode = HttpStatusCode.PartialContent;
} else {
response.StatusCode = HttpStatusCode.OK;
}
return response;
}