首先有一个html页面,页面有一个链接,点击链接弹出文件下载/保存(类似迅雷下载链接)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<!DOCTYPE html>
<html>
<head>
<meta http-equiv= "Content-Type" content= "text/html; charset=utf-8" />
<title>文件下载</title>
<meta charset= "utf-8" />
</head>
<body>
<!--该方式不行,1:如果访问的是类似文本等浏览器可以处理的文件,则是浏览器打开显示的方式,并不是文件下载;2:如果访问的是App_Data文件夹里的文件,由于.net的机制不允许访问App_Data文件夹资源,所以会报“请求筛选模块被配置为拒绝包含 hiddenSegment 节的 URL 中的路径。”-->
<a href= "App_Data/readme.txt" rel= "external nofollow" >下载readme.txt文件</a>
<br />
<a href= "DownloadFileHandler.ashx" rel= "external nofollow" >下载readme.txt文件</a>
</body>
</html>
|
一般处理程序的代码如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
using System.IO;
using System.Web;
namespace Zhong.Web
{
/// <summary>
/// DownloadFileHandler 的摘要说明
/// </summary>
public class DownloadFileHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
string filePath = context.Server.MapPath( "~/App_Data/readme.txt" );
FileStream fs = new FileStream(filePath, FileMode.Open);
byte [] bytes = new byte [fs.Length];
fs.Read(bytes, 0, bytes.Length);
fs.Dispose();
context.Response.ContentType = "application/octet-stream" ;
context.Response.AddHeader( "Content-Disposition" , "attachment; filename=readme.txt" );
context.Response.BinaryWrite(bytes);
context.Response.Flush();
//大文件下载的解决方案
//context.Response.ContentType = "application/x-zip-compressed";
//context.Response.AddHeader("Content-Disposition", "attachment;filename=z.zip");
//string filename = Server.MapPath("~/App_Data/move.zip");
//context.Response.TransmitFile(filename);
}
public bool IsReusable
{
get
{
return false ;
}
}
}
}
|
点击第一个链接访问,显示如下:
点击第二个链接访问,下载文件:
由于我之前已经测试过一次,所以这次下载时命名为readme(1).txt
原文链接:http://www.cnblogs.com/godbell/archive/2017/07/11/7149932.html