ASP.NET 大文件下载的实现思路及代码
2015-07-17 14:23
651 查看
文件下载是一个网站最基本的功能,ASP.NET网站的文件下载功能实现也很简单,但是如果遇到大文件的下载而不做特殊处理的话,那将会出现不可预料的后果。本文就基于ASP.NET提供大文件下载的实现思路及代码。
当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃。可以参考如下代码来避免这个问题。
关于此代码的几点说明:
1. 将数据分成较小的部分,然后将其移动到输出流以供下载,从而获取这些数据。
2. 根据下载的文件类型来指定 Response.ContentType 。(参考OSChina的这个网址可以找到大部分文件类型的对照表:http://tool.oschina.net/commons)
3. 在每次写完response时记得调用 Response.Flush()
4. 在循环下载的过程中使用 Response.IsClientConnected 这个判断可以帮助程序尽早发现连接是否正常。若不正常,可以及早的放弃下载,以释放所占用的服务器资源。
5. 在下载结束后,需要调用 Response.End() 来保证当前线程可以在最后被终止掉。
当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃。可以参考如下代码来避免这个问题。
using System; namespace WebApplication1 { public partial class DownloadFile : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { System.IO.Stream iStream = null; // Buffer to read 10K bytes in chunk: byte[] buffer = new Byte[10000]; // Length of the file: int length; // Total bytes to read. long dataToRead; // Identify the file to download including its path. string filepath = Server.MapPath("/") +"./Files/TextFile1.txt"; // Identify the file name. string filename = System.IO.Path.GetFileName(filepath); try { // Open the file. iStream = new System.IO.FileStream(filepath, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.Read); // Total bytes to read. dataToRead = iStream.Length; Response.Clear(); Response.ClearHeaders(); Response.ClearContent(); Response.ContentType = "text/plain"; // Set the file type Response.AddHeader("Content-Length", dataToRead.ToString()); Response.AddHeader("Content-Disposition", "attachment; filename=" + filename); // Read the bytes. while (dataToRead > 0) { // Verify that the client is connected. if (Response.IsClientConnected) { // Read the data in buffer. length = iStream.Read(buffer, 0, 10000); // Write the data to the current output stream. Response.OutputStream.Write(buffer, 0, length); // Flush the data to the HTML output. Response.Flush(); buffer = new Byte[10000]; dataToRead = dataToRead - length; } else { // Prevent infinite loop if user disconnects dataToRead = -1; } } } catch (Exception ex) { // Trap the error, if any. Response.Write("Error : " + ex.Message); } finally { if (iStream != null) { //Close the file. iStream.Close(); } Response.End(); } } } }
关于此代码的几点说明:
1. 将数据分成较小的部分,然后将其移动到输出流以供下载,从而获取这些数据。
2. 根据下载的文件类型来指定 Response.ContentType 。(参考OSChina的这个网址可以找到大部分文件类型的对照表:http://tool.oschina.net/commons)
3. 在每次写完response时记得调用 Response.Flush()
4. 在循环下载的过程中使用 Response.IsClientConnected 这个判断可以帮助程序尽早发现连接是否正常。若不正常,可以及早的放弃下载,以释放所占用的服务器资源。
5. 在下载结束后,需要调用 Response.End() 来保证当前线程可以在最后被终止掉。
相关文章推荐
- ASP.NET MVC程序中动态修改form的Action值
- 关于Aspcms如何嵌入整个网站,以及网站导航所指向页面的内容显示
- 【工作日志】【asp】【05】err对象使用
- ASP.NET 4.0尚未在 Web 服务器上注册 解决方法
- 在ASP.NET 4.0 Web form上使用Routing优化URL
- 利用Routing特性提高ASP.NET MVC3站点的SEO权重
- 【工作日志】【asp】【04】asp for each详解
- 在 ASP.NET 中执行 URL 重写的方法
- ASP.NET 泛型类型 Dictionary操作
- 【工作日志】【asp】【03】iis配置好后要改动的几个地方
- 关于Aspcms如何嵌入整个网站,以及网站导航所指向页面的内容显示
- ASP.NET 5中使用AzureAD实现单点登录
- ASP.NET网站前端页面的复制
- asp.net c# 网上搜集面试题目大全(附答案)
- ASP.NET - (Session)后台登陆时,判断是不是已经登陆,如果不是,跳转回登陆页
- ASP.NET常见面试题及答案(130题)
- asp.net mvc 简单文件下载
- ASP.NET - 锚点跳转,用于回到顶部
- ASP.NET - 记住滚动条的位置
- Using ASP.Net WebAPI with Web Forms