Handler文件代码如下:

  1. public class MDMExporterWeb : IHttpHandler
  2. {
  3.  
  4. public void ProcessRequest(HttpContext context)
  5. {
  6. string url = context.Request.Form["fileName"];
  7. //判断服务端是否生成Excel文件
  8. if (File.Exists(context.Server.MapPath(url)))
  9. {
  10. //获取文件路径和文件名
  11. string filePath = context.Server.MapPath(url);
  12. string fileName = Path.GetFileName(filePath);
  13.  
  14. //将文件转换为字节流
  15. //byte[] file = ImpExpWebPublic.ConvertToBinary(filePath);
  16. FileStream fs = new FileStream(filePath, FileMode.Open);
  17. byte[] bytes = new byte[(int)fs.Length];
  18. fs.Read(bytes, , bytes.Length);
  19. fs.Close();
  20.  
  21. using (MemoryStream stream = new MemoryStream(bytes))
  22. {
  23. //文件导出到客户端(Web)
  24. ResponseFile(context.Request, context.Response, fileName, stream, );
  25. }
  26. }
  27. else
  28. {
  29. context.Response.Write("<script> alert('错误信息:未导出Excel文件');window.close();</script>");
  30. }
  31. }
  32.  
  33. public bool IsReusable
  34. {
  35. get
  36. {
  37. return false;
  38. }
  39. }
  40.  
  41. /// <summary>
  42. /// 文件下载
  43. /// </summary>
  44. /// <param name="_Request">Request对象</param>
  45. /// <param name="_Response">Response对象</param>
  46. /// <param name="_fileName">文件名</param>
  47. /// <param name="stream">发送的流</param>
  48. /// <param name="block">每次读取的字节数</param>
  49. /// <returns></returns>
  50. public static bool ResponseFile(HttpRequest _Request, HttpResponse _Response, string _fileName, Stream stream, int block)
  51. {
  52. try
  53. {
  54. _Response.Clear();
  55. using (var br = new BinaryReader(stream))
  56. {
  57.  
  58. _Response.AddHeader("Accept-Ranges", "bytes");
  59. _Response.Buffer = false;
  60. long fileLength = stream.Length;
  61. long startBytes = ;
  62.  
  63. int pack = block; //每次读取的字节数
  64. if (_Request.Headers["Range"] != null)
  65. {
  66. _Response.StatusCode = ;
  67. string[] range = _Request.Headers["Range"].Split(new char[] { '=', '-' });
  68. startBytes = Convert.ToInt64(range[]);
  69. }
  70. _Response.AddHeader("Content-Length", (fileLength - startBytes).ToString());
  71. if (startBytes != )
  72. {
  73. _Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength - , fileLength));
  74. }
  75. _Response.AddHeader("Connection", "Keep-Alive");
  76. _Response.ContentType = "application/octet-stream";
  77.  
  78. _Response.AddHeader("Content-Disposition", "attachment;filename=" + Uri.EscapeUriString(_fileName));
  79.  
  80. br.BaseStream.Seek(startBytes, SeekOrigin.Begin);
  81. int maxCount = (int)Math.Floor((fileLength - startBytes) / (double)pack) + ;
  82.  
  83. for (int i = ; i < maxCount; i++)
  84. {
  85. if (_Response.IsClientConnected)
  86. {
  87. _Response.BinaryWrite(br.ReadBytes(pack));
  88. }
  89. else
  90. {
  91. i = maxCount;
  92. }
  93. }
  94. br.Close();
  95. stream.Close();
  96. }
  97. }
  98. catch (Exception e)
  99. {
  100. _Response.Write(e.Message + e.StackTrace);
  101. _Response.Flush();
  102. }
  103. return true;
  104. }
  105. }

javascript代码如下:

  1. var fileName = '/cwbase/test1.xls';//相对路径
  2. var postUrlE = '/cwbase/MDMWeb/MDMExporterWeb.ashx';
  3. var form = $('<form action="' + postUrlE + '" method="POST" name="fileDownload" id="fileDownload" target="_blank"></form>');
  4. $('<input type="text" name="fileName" value="' + fileName + '">').appendTo(form);
  5. $(form).appendTo('body');
  6. form.submit();//表单提交
  7. $(form).remove();
  8.  
  9. document.characterSet = 'UTF-8';
  10. document.charset = 'UTF-8';

.net一般处理程序(httphandler)实现文件下载功能的更多相关文章

  1. ASP.NET网页中RAR、DOC、PDF等文件下载功能实例源代码

    以前做asp.net下载功能的时候都是采用:<a href="http://www.wang0214.com/wgcms">下载</a>的方式来实现下载. ...

  2. JAVA文件下载功能问题解决日志

    今天给报告系统做了个下载功能,遇到了挺多问题,通过查资料一一解决了. 1.首先遇到的问题是:java后台的输出流输出之后,没有任何报错,浏览器端不弹出保存文件的对话框,原本是ajax请求到后台的con ...

  3. 解决springmvc中文件下载功能中使用javax.servlet.ServletOutputStream out = response.getOutputStream();后运行出异常但结果正确的问题

    问题描述: 在springmvc中实现文件下载功能一般都会使用javax.servlet.ServletOutputStream out = response.getOutputStream();封装 ...

  4. WebView实现文件下载功能

    WebView控制调用相应的WEB页面进行展示.安卓源码当碰到页面有下载链接的时候,点击上去是一点反应都没有的.原来是因为WebView默认没有开启文件下载的功能,如果要实现文件下载的功能,需要设置W ...

  5. HttpHandler 实现文件下载

    一个浏览者发出的请求都是由实现了IHttpHandler接口的对象进行响应,由于下次访问不一定还是上次那个对象进行响应,上次响应完毕对象可能已经被销毁了,写的类变量值早就不存在了,因此不将状态信息保存 ...

  6. Spring Boot实现文件下载功能

    我们只需要创建一个控制器(Controler)文件,即Controller目录下的File_Download.java,其完整目录如下: @Controller public class File_D ...

  7. Spring Boot入门(11)实现文件下载功能

      在这篇博客中,我们将展示如何在Spring Boot中实现文件的下载功能.   还是遵循笔者写博客的一贯风格,简单又不失详细,实用又能让你学会.   本次建立的Spring Boot项目的主要功能 ...

  8. 002-一般处理程序(HttpHandler)

    一般处理程序(HttpHandler):是一个实现System.Web.IHttpHandler接口的特殊类.任何一个实现了IHttpHandler接口的类,是作为一个外部请求的目标程序的前提.(凡是 ...

  9. java web文件下载功能实现 (转)

    http://blog.csdn.net/longshengguoji/article/details/39433307 需求:实现一个具有文件下载功能的网页,主要下载压缩包和图片 两种实现方法: 一 ...

  10. 【Servlet】java web 文件下载功能实现

    需求:实现一个具有文件下载功能的网页,主要下载压缩包和图片 两种实现方法: 一:通过超链接实现下载 在HTML网页中,通过超链接链接到要下载的文件的地址 <!DOCTYPE html> & ...

随机推荐

  1. ASP.NET - Web API,从简单类型到复杂类型的参数传递用例,以及传递简单string类型的解决办法

    一,简单类型的传值 比如 public Users Get(int id) ,它可以使用两种方式获取: api/default/ $.get("/api/default",{id: ...

  2. Java NIO使用及原理分析(1-4)(转)

    转载的原文章也找不到!从以下博客中找到http://blog.csdn.net/wuxianglong/article/details/6604817 转载自:李会军•宁静致远 最近由于工作关系要做一 ...

  3. iOS App上架流程(2016详细版)

    iOS App上架流程(2016详细版) 原文地址:http://www.jianshu.com/p/b1b77d804254 感谢大神整理的这么详细 一.前言: 作为一名iOSer,把开发出来的Ap ...

  4. jQuery的页面载入

    jQuery 页面载入 $(document).ready(function(){ //程序段 }) 原生javaScript window.onload = function(){ //程序段 } ...

  5. 版本管理工具svn简介

    svn简介 SVN是一种C/S架构的版本管理软件 , 能够帮助我们保存开发过程中各个文件的所有历史版本, 你因此可以方便的找回软件的任何一个历史状态., 日常开发中经常用到. 安装使用 1.  在 u ...

  6. PHP 扩展开发(将自己的一些代码封装成PHP扩展函数)

    今天时间不多,先给个地址,能搜到我这篇blog的朋友先看看我最近在看的一些文章.资料吧: 我的环境是 lnmp1.1 的 (LNMP一键安装包),所以要进行PHP扩展开发首先应该对环境配置和shell ...

  7. 在windows上部署使用Redis

    参考地址: http://keenwon.com/1275.html

  8. 被误解的MVC和被神化的MVVM(转)

    转载自:http://www.infoq.com/cn/articles/rethinking-mvc-mvvm 原文作者:唐巧 被误解的 MVC MVC 的历史 MVC,全称是 Model View ...

  9. SVO原理解析

    最近空闲时间在研究Semi-Direct Monocular Visual Odometry(SVO)[1,2],觉得它值得写一写.另外,SVO的运算量相对较小,我想在手机上尝试实现它. 关于SVO的 ...

  10. react 表单

    import React ,{PropTypes}from 'react'; import { render } from 'react-dom'; const styles={ mb10:{ mar ...