有一个大文件下载的问题,这两天查了一下,主要原因有两个:
- 发送的Get请求中,没有设置HttpCompletionOption这个参数,当下载大文件的时候,会等到response body中的数据全部加载完才开始下载。现在已经改成了HttpCompletionOption.ResponseHeadersRead,这样只要head加载完就可以开始下载
- 下载的时候使用FileStreamResult File(Stream fileStream, string contentType, string fileDownloadName) 这个方法直接把stream返回给前台,如果文件不大的话没问题, 如果文件比较大的话,下载的时候会造成内存OutOfMemoryException,如果有大文件下载需求的模块,请使用分块下载的方式下载, 下面是个demo仅供参考
private void DownloadFile(string fileName, Stream iStream)
{
const int chunkSize = 102400;//100K 每次读取文件,只读取100K,这样可以缓解服务器的压力
byte[] buffer = new byte[chunkSize];
Response.Clear();
Response.ContentType = "application/octet-stream";
Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode("1.zip"));
int offset = 0;
int read = 0;
while ((read = iStream.Read(buffer, offset, chunkSize)) > 0)
{
if (!Response.IsClientConnected)
break;
Response.OutputStream.Write(buffer, 0, read);
Response.Flush();
}
Response.Close();
}
时间: 2025-01-02 17:25:12