ASP.NET 下载大文件(分块下载)

直接上代码:

var filePath = @"D:\Download\测试文档.xlsx";//要下载的文件地址,这个文件会被分成片段,通过循环逐步读取到ASP.NET Core中,然后发送给客户端浏览器
var fileName = Path.GetFileName(filePath);//测试文档.xlsx

int dataBufferSize = 50 * 1024 * 1024;   //每次分批加载的50m
var response = HttpContext.Current.Response;    //上下文的HttpResponse
response.Headers.Add("ContentType", "application/octet-stream");
var contentDisposition = new ContentDispositionHeaderValue("attachment")
{
    FileName = fileName
};
response.Headers.Add("Content-Disposition", contentDisposition.ToString());
//分块下载
using (FileStream fs = new FileStream(targetFile, FileMode.Open, FileAccess.Read))
{
    long contentLength = stream.Length; //获取数据流的大小
    byte[] buffer;
    long hasRead = 0;//变量hasRead用于记录已经发送了多少字节的数据到客户端浏览器
    response.Clear();
    //如果hasRead小于contentLength,说明下载文件还没读取完毕,继续循环读取下载文件的内容,并发送到客户端浏览器
    while (hasRead < contentLength)
    {
        if (!response.IsClientConnected)
        {
            //如果客户端浏览器中断了到ASP.NET服务器的连接,这里应该立刻break,取消下载文件的读取和发送,避免服务器耗费资源
            break;
        }

        buffer = new byte[dataBufferSize];
        int currentRead = stream.Read(buffer, 0, dataBufferSize);//从数据流中读取bufferSize大小的内容到服务器内存中
        response.OutputStream.Write(buffer, 0, currentRead);    //发送读取的内容数据到客户端浏览器
        response.Flush();          //注意每次Write后,要及时调用Flush方法,及时释放服务器内存空间

        hasRead += currentRead;//更新已经发送到客户端浏览器的字节数
    }
    response.Close();
}
Asp.Net core 版本可以参考 :https://www.cnblogs.com/OpenCoder/p/10013240.html

猜你喜欢

转载自www.cnblogs.com/luzm/p/12922228.html