Revert "Change PhysicalFileResult and VirtualFileResult to use SendFileAsync"
This reverts commit 5aa2e06305.
This commit is contained in:
parent
5aa2e06305
commit
ba5fe60cf5
|
|
@ -3,8 +3,10 @@
|
|||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.AspNet.Http;
|
||||
using Microsoft.AspNet.Http.Features;
|
||||
using Microsoft.AspNet.Mvc.Core;
|
||||
using Microsoft.Net.Http.Headers;
|
||||
|
||||
|
|
@ -16,6 +18,7 @@ namespace Microsoft.AspNet.Mvc
|
|||
/// </summary>
|
||||
public class PhysicalFileResult : FileResult
|
||||
{
|
||||
private const int DefaultBufferSize = 0x1000;
|
||||
private string _fileName;
|
||||
|
||||
/// <summary>
|
||||
|
|
@ -80,14 +83,52 @@ namespace Microsoft.AspNet.Mvc
|
|||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
protected override Task WriteFileAsync(HttpResponse response)
|
||||
protected override async Task WriteFileAsync(HttpResponse response)
|
||||
{
|
||||
if (!Path.IsPathRooted(FileName))
|
||||
{
|
||||
throw new NotSupportedException(Resources.FormatFileResult_PathNotRooted(FileName));
|
||||
}
|
||||
|
||||
return response.SendFileAsync(FileName);
|
||||
var sendFile = response.HttpContext.Features.Get<IHttpSendFileFeature>();
|
||||
if (sendFile != null)
|
||||
{
|
||||
await sendFile.SendFileAsync(
|
||||
FileName,
|
||||
offset: 0,
|
||||
length: null,
|
||||
cancellation: default(CancellationToken));
|
||||
}
|
||||
else
|
||||
{
|
||||
var fileStream = GetFileStream(FileName);
|
||||
|
||||
using (fileStream)
|
||||
{
|
||||
await fileStream.CopyToAsync(response.Body, DefaultBufferSize);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns <see cref="Stream"/> for the specified <paramref name="path"/>.
|
||||
/// </summary>
|
||||
/// <param name="path">The path for which the <see cref="FileStream"/> is needed.</param>
|
||||
/// <returns><see cref="FileStream"/> for the specified <paramref name="path"/>.</returns>
|
||||
protected virtual Stream GetFileStream(string path)
|
||||
{
|
||||
if (path == null)
|
||||
{
|
||||
throw new ArgumentNullException(nameof(path));
|
||||
}
|
||||
|
||||
return new FileStream(
|
||||
path,
|
||||
FileMode.Open,
|
||||
FileAccess.Read,
|
||||
FileShare.ReadWrite,
|
||||
DefaultBufferSize,
|
||||
FileOptions.Asynchronous | FileOptions.SequentialScan);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -106,9 +106,14 @@ namespace Microsoft.AspNet.Mvc
|
|||
if (fileInfo.Exists)
|
||||
{
|
||||
var physicalPath = fileInfo.PhysicalPath;
|
||||
if (!string.IsNullOrEmpty(physicalPath))
|
||||
var sendFile = response.HttpContext.Features.Get<IHttpSendFileFeature>();
|
||||
if (sendFile != null && !string.IsNullOrEmpty(physicalPath))
|
||||
{
|
||||
await response.SendFileAsync(physicalPath);
|
||||
await sendFile.SendFileAsync(
|
||||
physicalPath,
|
||||
offset: 0,
|
||||
length: null,
|
||||
cancellation: default(CancellationToken));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
|||
Loading…
Reference in New Issue