如果下载文件是中文名,产生乱码 原因: 不同浏览器 默认解码机制不同
IE使用URL解码 、FF使用 BASE64解码 浏览器本身设计机制
先可以解决ie乱码:URLEncoder
设置 response.setHeader(“Content-Disposition”, “attachment;filename=” + filename);
出现附件名乱码 :filename 需要编码输出。
不同浏览器处理下载附件名乱码 处理方式不同 ,
解决乱码问题我们需要获取不同的浏览器头信息。
通过USER-AGENT 请求头信息字段,判断来访者浏览器类型 request对象获取
解决:采用手动BASE64 编码
BASE64Encoder base64Encoder = new BASE64Encoder();
filename = "=?utf-8?B?" + base64Encoder.encode(filename.getBytes("utf-8")) + "?=";
判断不同的浏览器下载的中文编码处理 模版代码:
工具代码:
String agent = request.getHeader("user-agent");
String realname = resource.getRealname();
if (agent.contains("Firefox")) {// 采用BASE64编码
realname = "=?UTF-8?B?"
+ new BASE64Encoder().encode(realname
.getBytes("utf-8")) + "?=";
} else {
// 其它浏览器 IE 、google 采用URL编码
realname = URLEncoder.encode(realname, "utf-8");
realname = realname.replace("+", " ");
} response.setHeader("Content-Disposition",
"attachment;filename=" + realname);