JavaWeb笔记——下载文件
核心内容是两个头一个流
> 头:Content-Type:你传递给客户端的文件是什么MIME类型,例如:image/pjpeg
* 通过文件名称调用ServletContext的getMimeType()方法,得到MIME类型
> 头:Content-Disposition:它的默认值为inline,表示在浏览器窗口中打开。需设置为attachment;filename=xxx
* 在filename=后面跟随的是显示在下载框中的文件名称!
> 流:要下载的文件数据!
* 自己new一个输入流即可!
![图片](http://r.photo.store.qq.com/psb?/V12MyHON4TqWm3/Ld9ia3uCWPHM7FtGYDm.0kP.1Dcyu15puqtbZlQoieU!/o/dIcBAAAAAAAA&ek=1&kp=1&pt=0&bo=*wNEAv8DRAIDACU!&su=126035073&sce=0-12-12&rf=2-9)
![图片](http://r.photo.store.qq.com/psb?/V12MyHON4TqWm3/.EfuYC0Yuvdxcp4laYwxQB4xMmFyftRfUvlp362zaWU!/o/dG8AAAAAAAAA&ek=1&kp=1&pt=0&bo=*gHsAP4B7AADACU!&su=1253523441&sce=0-12-12&rf=2-9)
==========
下载的细节
==========
==========
下载的细节
==========
显示在下载框中的中文名称时,会出现乱码。
* FireFox:Base64编码。
* 其他大部分浏览器:URL编码。
通用解决方案:filename = new String(filename.getBytes("GBK"), "ISO-8859-1");
public static String filenameEncoding(String filename, HttpServletRequest request) throws IOException {
String agent = request.getHeader("User-Agent"); //获取浏览器
if (agent.contains("Firefox")) {
BASE64Encoder base64Encoder = new BASE64Encoder();
filename = "=?utf-8?B?"
+ base64Encoder.encode(filename.getBytes("utf-8"))
+ "?=";
} else if(agent.contains("MSIE")) {
filename = URLEncoder.encode(filename, "utf-8");
} else {
filename = URLEncoder.encode(filename, "utf-8");
}
return filename;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。