ashx灵活处理文件下载问题

简介:   新建一般处理程序 ,改下面的函数:         public void ProcessRequest(HttpContext context)         {             string filename;    ...

 

新建一般处理程序 ,改下面的函数:

        public void ProcessRequest(HttpContext context)
        {
            string filename;
            try
            {

                filename = context.Request["filename"].ToString();
            }
            catch
            {
                context.Response.Write("不正确的访问!");
                return;
            }

            string RealFile = context.Server.MapPath("~/Upload/files/" + filename);//真实存在的文件
            if (!System.IO.File.Exists(RealFile))
            {
                context.Response.Write("服务器上该文件已被删除或不存在!"); return;
            }
            context.Response.Buffer = true;
            context.Response.Clear();
            context.Response.ContentType = "application/download";
            string downFile=System.IO.Path.GetFileName(filename);//这里也可以随便取名
            string EncodeFileName = HttpUtility.UrlEncode(downFile, System.Text.Encoding.UTF8);//防止中文出现乱码
            context.Response.AddHeader("Content-Disposition", "attachment;filename=" + EncodeFileName + ";");
            context.Response.BinaryWrite(System.IO.File.ReadAllBytes(RealFile));//返回文件数据给客户端下载
            context.Response.Flush();
            context.Response.End();
        }
 

 

相关文章
|
2月前
|
JSON 前端开发 Go
前端文件下载的方式
【10月更文挑战第5天】
114 58
|
3月前
|
前端开发 JavaScript
前端JS控制网页复制粘贴
前端JS控制网页复制粘贴
|
Web App开发 JavaScript 前端开发
前端接收数据流实现图片预览效果--ajax 请求二进制流 图片 文件 XMLHttpRequest 请求并处理二进制流数据 之最佳实践
本文为转载文章 原文链接:https://www.cnblogs.com/cdemo/p/5225848.html 首先要谢谢这位大神的无私贡献!解决了我的问题也完美表达了我当时的心路历程 ajax 请求二进制流 图片 文件 XMLHttpRequest 请求并处理二进制流数据 之最佳实践 写在前面 :从提出需求到完美的解决问题,实现过程是曲折的。
8100 0
|
7月前
|
XML 机器学习/深度学习 JSON
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
77 0
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
视频文件上传接口上传不了,怎样解决??
视频文件上传接口上传不了,怎样解决??
|
前端开发
前端常规关于网页文件下载的问题
前端常规关于网页文件下载的问题
63 0
|
前端开发
前端:下载文件(多种方法)
前端:下载文件(多种方法)
868 0
|
7月前
|
JSON 前端开发 JavaScript
前端上传文件前检测文件数据🔍
前端上传文件前检测文件数据🔍
128 0
|
移动开发 前端开发 JavaScript
前端实现PDF文件下载的两种方式
前端实现PDF文件下载的两种方式
2366 0
前端实现PDF文件下载的两种方式
|
前端开发 JavaScript
前端js一些技巧性方法
前端js一些技巧性方法
122 0