zoukankan      html  css  js  c++  java
  • C#文件下载两种方式

    1.普通下载:

            //下载文件的路径
            string path=Server.MapPath("广告.jpg");
            //下载文件的名称
            string filename = "广告.jpg";
            System.IO.FileInfo toDownload = new System.IO.FileInfo(path);
            Response.Clear();
            if (System.IO.Path.GetExtension(filename) == ".jpg")
            {
                Response.AddHeader("Content-Disposition", "attachment;filename=NEW_" + HttpUtility.UrlEncode(toDownload.Name));
                Response.ContentType = "application/x-zip-compressed";
                Response.TransmitFile(path);
                Response.End();
            }
    2.大文件分成小块下载:

            //下载文件的路径
            string path = Server.MapPath("广告.jpg");
            //下载文件的名称
            string filename = "广告.jpg";
            System.IO.FileInfo toDownload = new System.IO.FileInfo(path);

            if (toDownload.Exists == true)
            {
                const long ChunkSize = 10000;
                byte[] buffer = new byte[ChunkSize];

                Response.Clear();
                System.IO.FileStream iStream = System.IO.File.OpenRead(path);
                long dataLengthToRead = iStream.Length;
                Response.ContentType = "application/octet-stream";
                Response.AddHeader("Content-Disposition", "attachment; filename=new_" + HttpUtility.UrlEncode(toDownload.Name));
                while (dataLengthToRead > 0 && Response.IsClientConnected)
                {
                    int lengthRead = iStream.Read(buffer, 0, Convert.ToInt32(ChunkSize));
                    Response.OutputStream.Write(buffer, 0, lengthRead);
                    Response.Flush();
                    dataLengthToRead = dataLengthToRead - lengthRead;
                }
                Response.Close();
            }

    Kyle

  • 相关阅读:
    Boost Started on Windows
    7-Zip
    代码的命名规则
    基础扫盲:YEAR关键字 IN操作符
    基础扫盲:INSERT INTO 和 SELECT 结合使用
    知识盲点:存在外键的的表,在插入数据时应该如何操作?
    SQL Identity函数
    SQL 中DateName()函数及DatePart()函数
    OS开发多线程篇—GCD介绍
    经典SQL语句大全
  • 原文地址:https://www.cnblogs.com/lovewife/p/1428811.html
Copyright © 2011-2022 走看看