有些时候为了保证文件再上传时不会覆盖掉之前上传的文件,同时由于上传的目标目录里的文件可能很多,这个时候一个一个查是不太好的事情,所以这里可以自动生成GUID使文件名重命名成GUID_原来的名称.扩展名。但是在下载的时候最好可能保证恢复到原来的名称。这个时候听伤神的。搜了一下相关资料后得知可使用response来解决。具体代码如下。
[csharp]
复制代码 代码如下:
pre name="code" class="csharp">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>
您可能感兴趣的文章:- ASP.NET Web Api 2实现多文件打包并下载文件的实例
- ASP.NET(C#) Web Api通过文件流下载文件的实例
- ASP.NET批量下载文件的方法
- asp.net C#实现下载文件的六种方法实例
- ASP.NET中下载文件的几种实例代码
- 在ASP.NET中下载文件的实现代码
- asp.net BackgroundWorker之在后台下载文件
- asp.net 下载文件时根据MIME类型自动判断保存文件的扩展名
- asp.net 下载文件时输出文件内容
- asp.net Web Services上传和下载文件(完整代码)
- ASP.NET实现从服务器下载文件问题处理