• 文件下载


    文件下载
    public static bool ResponseFile(HttpRequest _Request, HttpResponse _Response, string _fileName, string _fullPath, long _speed)
    {
    try
    {
    FileStream myFile
    = new FileStream(_fullPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
    BinaryReader br
    = new BinaryReader(myFile);
    try
    {
    _Response.AddHeader(
    "Accept-Ranges", "bytes");
    _Response.Buffer
    = false;
    long fileLength = myFile.Length;
    long startBytes = 0;

    double pack = 10240; //10K bytes
    //int sleep = 200; //每秒5次 即5*10K bytes每秒
    int sleep = (int)Math.Floor(1000 * pack / _speed) + 1;
    if (_Request.Headers["Range"] != null)
    {
    _Response.StatusCode
    = 206;
    string[] range = _Request.Headers["Range"].Split(new char[] { '=', '-' });
    startBytes
    = Convert.ToInt64(range[1]);
    }
    _Response.AddHeader(
    "Content-Length", (fileLength - startBytes).ToString());
    if (startBytes != 0)
    {
    //Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength-1, fileLength));
    }
    _Response.AddHeader(
    "Connection", "Keep-Alive");
    _Response.ContentType
    = "application/octet-stream;charset=gbk";
    _Response.AddHeader(
    "Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(_fileName, System.Text.Encoding.UTF8));

    br.BaseStream.Seek(startBytes, SeekOrigin.Begin);
    int maxCount = (int)Math.Floor((fileLength - startBytes) / pack) + 1;

    for (int i = 0; i < maxCount; i++)
    {
    if (_Response.IsClientConnected)
    {
    _Response.BinaryWrite(br.ReadBytes(
    int.Parse(pack.ToString())));
    Thread.Sleep(sleep);
    }
    else
    {
    i
    = maxCount;
    }
    }
    }
    catch
    {
    return false;
    }
    finally
    {
    br.Close();

    myFile.Close();
    }
    }
    catch
    {
    return false;
    }
    return true;
    }
    调用方法
    ExportExcel excel = new ExportExcel();
    string fileName = excel.Export(dt, "项目统计", DataName);
    string path = Request.PhysicalApplicationPath + "Excel\\" + fileName + ".xls";
    DownFile.ResponseFile(Page.Request, Page.Response, fileName
    + ".xls", path, 1024000);

    没搞清楚到底是什么原理,留下,等以后研究。

  • 相关阅读:
    21 jsp——jsp中的相对路径和绝对路径
    20 jsp——jsp的九大内置对象
    19 jsp——jsp的转发标签
    18 jsp——静态引入和动态引入
    17 jsp——全局代码,局部代码
    【zabbix告警监控】配置zabbix监控nginx服务
    【nagios监控】基于linux搭建nagios监控
    【zabbix监控问题】记录zabbix控制面板报错及日志报错的解决方法
    【docker构建】基于docker构建rabbitmq消息队列管理服务
    【docker构建】基于docker搭建redis数据库缓存服务
  • 原文地址:https://www.cnblogs.com/smartsky/p/1880947.html
Copyright © 2020-2023  润新知