ASP.NET 大文件下载程序与思路原理

当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃。可以参考如下代码来避免这个问题。

 

 代码如下 复制代码
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() 来保证当前线程可以在最后被终止掉。

时间: 2024-12-27 18:17:11

ASP.NET 大文件下载程序与思路原理的相关文章

ASP.NET 大文件下载的实现思路及代码

当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃.可以参考如下代码来避免这个问题. using System;  namespace WebApplication1  {      public partial class DownloadFile : System.Web.UI.Page      {          protected void Page_Load(object sender, EventArgs e)         

在ASP.NET中跟踪和恢复大文件下载

asp.net|恢复|下载 在Web应用程序中处理大文件下载的问题一直出了名的困难,因此对于大多数站点来说,如果用户的下载被中断了,它们只能说悲哀降临到用户的身上了.但是我们现在不必这样了,因为你可以使自己的ASP.NET应用程序有能力支持可恢复(继续)的大文件下载.使用本文提供的方法的时候,你可以跟踪下载的过程,这样你就可以处理动态建立的文件--而且要达到这个目标根本不需要旧式的ISAPI动态链接库和非受控的(unmanaged)C++代码. 为客户端提供从互联网上下载文件的服务最容易了,对吗

请问asp.net写的文件下载程序为什么用快车会把整个页面下载下来呢

问题描述 请问asp.net写的文件下载程序,在点击下载时,右键另存为没问题,可是为什么用快车下载时,在另存为框里是页面名称,如果不修改名称就会把整个页面下载下来呢?如何让另存为框里显示文件的名称而不是页面名称呢?请高手帮忙,谢谢. 解决方案 解决方案二:sf解决方案三:是不是点错地方了!第一次见你这类问题!解决方案四:我也是这头次遇到,没有点错地方解决方案五:有些网站限制了不能使用多线程下载,否则URL转向错误就会找不到下载文件直接把网页下载下来右键另存为其实网页做了转向,有的网站禁止多线程下

基于vs2010的asp.net,幸运大抽奖程序

问题描述 基于vs2010的asp.net,幸运大抽奖程序 基于vs2010的asp.net,幸运大抽奖程序,要求有颁奖功能,请问颁奖功能是什么意思?和抽奖的区别是什么? 解决方案 http://www.51aspx.com/code/HanChouJiangMS 解决方案二: http://www.haolizi.net/example/view_294.html

ASP.NET中大文件下载的跟踪和恢复

在Web应用程序中处理大文件下载的问题一直出了名的困难,因此对于大多数站点来说,如果用户的下载被中断了,它们只能说悲哀降临到用户的身上了.但是我们现在不必这样了,因为你可以使自己的ASP.NET应用程序有能力支持可恢复(继续)的大文件下载.使用本文提供的方法的时候,你可以跟踪下载的过程,这样你就可以处理动态建立的文件--而且要达到这个目标根本不需要旧式的ISAPI动态链接库和非受控的(unmanaged)C++代码. 为客户端提供从互联网上下载文件的服务最容易了,对吗?仅仅只需要把可下载的文件复

“菜鸟”程序员和“大神”程序员差距在哪里

"菜鸟"和"大神" 刚刚走出就业的程序员,技术是刚刚起步的基点.那下面我们就聊一聊有关技术 的东西.首先请您先想想这几个问题.现在社会上有很多程序员,CSDN就是我们程序员的家,那您是否可想过程序员为什么会有不同的水平?你又是哪一类的程 序员?"菜鸟"程序员和"大神"程序员差在哪里?真是差在技术上了吗?那不是差在技术上那差在了哪里? 上面很多一连串的问题,没有把你搞晕吧!那就听我一一给您分析这个问题背后的答案.确切的说程序员分

浅析三线程程序开发思路与实现

一.前言 中国黑客(worm.runouce)病毒在国内出现以后,各大反病毒公司都对其进行了"仔细"的分析,得出一个结论:"中国黑客"发现了全球首创的"三线程"结构.这是某公司对外的宣传词,我个人对病毒没什么研究,并且我对worm.runouce没有任何的个人看法,不过我可以确信的是很多反病毒公司往往在夸大事实,目的只有一个:让更多的用户觉得某某病毒很可怕,让更多的用户相信只有某某公司的杀毒软件才可以彻底将病毒清除掉.其实三线程并没有好高深的技术

ASP.NET 2.0程序的安全知识

成员关系的概念在人类社会中是一个层次比较低的概念,源于希望属于某个群组的意识.同样,在ASP.NET 2.0程序开始开发涉及到成员关系的应用程序时,必须首先理解身份.验证和授权这几个关键的概念. 成员关系的概念在人类社会中是一个层次比较低的概念,源于希望属于某个群组的意识.我们希望能觉得自己是某个团队的一部分,让别人知道我们是谁,因此Web搭上这个流行趋势,采用这个概念只是时间早晚的问题.如果坐下来想一想曾经登录过多少个站点并在这些站点上保存了简单的用户信息,可能会发现自己所属的群组比一开始想象

矩阵-c++技术帮,给个程序的思路

问题描述 c++技术帮,给个程序的思路 编写一个实现n维向量各种操作的类(Vector),功能包括: 1. 构造函数实现n维向量的初始化构造,这里n可变: 2. 析构函数实现向量动态内存的释放: 3. 拷贝构造函数和移动拷贝构造函数实现向量的拷贝构造: 4. 重载赋值运算符('=')和移动赋值运算符,实现两个向量之间的赋值: 5. 编写成员函数求两个向量的内积: 6. 编写成员函数求两个向量的外积: 7. 编写成员函数求两个向量的和: 8. 编写成员函数求两个向量的差: 9. 编写成员函数实现向