首页 > 编程 > .NET > 正文

ASP.NET 在下载文件时对其重命名的思路及实现方法

2024-07-10 13:16:16
字体:
来源:转载
供稿:网友
有些时候为了保证文件再上传时不会覆盖掉之前上传的文件,同时由于上传的目标目录里的文件可能很多,这个时候一个一个查是不太好的事情,所以这里可以自动生成GUID使文件名重命名成GUID_原来的名称.扩展名。但是在下载的时候最好可能保证恢复到原来的名称。这个时候听伤神的。搜了一下相关资料后得知可使用response来解决。具体代码如下。

[csharp] 

复制代码 代码如下:


<pre>string path = Server.MapPath("aa//ahaakladahsasdas_bb.zip"); 
            string newfileName = ""; 
            if (File.Exists(path)) 
            { 
                FileInfo fi = new FileInfo(path); 
                Response.Clear();//Clear 方法删除缓冲区中的所有 HTML 输出。但 Clear 方法只删除响应正文 
                //而不删除响应标题。可以用该方法处理错误情况。 
                Response.ClearHeaders(); 
                Response.Buffer = false;//这句话的意思就是指明输出页面是否被缓冲,当属性值为True时, 
                //服务器将不会向客户端发送任何信息,直到所有程序执行完或者遇到  
                //Response.Flush或Response.End语句,才会释放缓冲区的信息。 
                string filename = Path.GetFileName(path); 
                newfileName = newfileName + filename.Substring(filename.LastIndexOf(".")); 
                Response.Clear(); 
                Response.ClearHeaders(); 
                Response.Buffer = false; 

                newfileName = HttpUtility.UrlEncode(newfileName);// 这一步弹出下载保存的对话框,出现文件名乱码,但变量中的文件名是正常的。   
                Response.AppendHeader("Content-Disposition", "attachment;filename=" + newfileName);//为用户保存文件是显示的名称 
                //告诉客户端这个响应内容的类型为attachment 你是通过Response.AppendHeader("content-type", "attachment"); 申明的。 

                Response.AppendHeader("Content-Length", fi.Length.ToString()); 
                Response.ContentType = "application/octet-stream"; 
                Response.WriteFile(newfileName);//用response来返回文件的路径   
                Response.Flush();//清空response   
                Response.End(); 
                //Response.End(); 如果抛异常的话可使用 
                //HttpContext.Current.ApplicationInstance.CompleteRequest(); 
            } 
            else 
            { 
                Response.Write("<script langauge=javascript>alert(‘文件不存在!');</script>"); 
            }


</pre><br> 
<br> 
<pre></pre> 
<p></p> 
<pre></pre> 
<p></p> 
<pre></pre> 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表