乱码的原因是什么?
每个浏览器的编码不一样,火狐采用的是base64.ie和谷歌采用的是url编码
所以我们在设置响应头的时候
Content-Type getServletContext().getMineType(filename);
Content-Disposition accachment;filename=编码后的filename
url编码
name = URLEncoder.encode(filename, "UTF-8");
base64编码
/**
- 传入文件的名称,进行Base64编码
- @param fileName
- @return
*/
public String base64EncodeFileName(String fileName) {
BASE64Encoder base64Encoder = new BASE64Encoder();
try {
return "=?UTF-8?B?"- new String(base64Encoder.encode(fileName
.getBytes("UTF-8"))) + "?=";
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
- new String(base64Encoder.encode(fileName
原文地址:http://blog.51cto.com/13579086/2073595
时间: 2024-10-09 14:33:23