HTTP消息头Content-Disposition 的运用(国际化语言环境下下载文件时文件名乱码问题处理)
程序员文章站
2024-03-20 21:14:10
...
问题背景: 导出报表,下载文件后有文件名乱码的情况。问题修复多次后仍有特定环境下乱码的情况,以下贴出几次历史修改的核心代码
response.setHeader("Content-Disposition", "attachment;filename=\"" + new String(exportFileName.getBytes("GBK"), "ISO-8859-1") + "\"");
问题:*windows操作系统环境下(系统语环境编码:950(big5)) 导出文件文件名乱码,GBK改成big5虽然繁体中文操作系统访问不乱,但简体中文操作系统(GBK)环境不行。
response.setHeader("Content-Disposition", "attachment;filename=\"" + new String(exportFileName.getBytes("UTF-8"), "ISO-8859-1") + "\"");
问题:chrome浏览器不乱码,但IE不行
完美解决方案:
response.setHeader("Content-Disposition", "attachment;filename=\"" + encodedName + "\";filename*=utf-8''" + encodedName);
此处的encodedName 要求对文件名URL编码(URLEncoder.encode(文件名))
代码截取:
private void setResponseHeaders(HttpServletResponse response, String exportFileName)
throws UnsupportedEncodingException {
String mimeType = MimeUtils.getFileMimeType(exportFileName);
if (StringUtils.isNotBlank(mimeType)) {
response.setContentType(mimeType);
}
String charset = "UTF-8";
// 2011年 RFC 6266 发布,正式将 Content-Disposition 纳入 HTTP 标准,并再次强调了 RFC 5987
// 中多语言编码的方法,并给出了一个范例用于解决向后兼容的问题
// Content-Disposition:
// attachment;filename="encoded_text";filename*=utf-8''encoded_text
// Firefox 、 Chrome 、 Opera 、 Safari 等浏览器,都支持新标准规定的 filename*
// ,IE支持filename="encoded_text"
String encodedName = URLEncoder.encode(exportFileName, charset);
response.setHeader("Content-Disposition",
"attachment;filename=\"" + encodedName + "\";filename*=utf-8''" + encodedName);
response.setHeader("Cache-Control", "must-revalidate, post-check=0, pre-check=0");
response.setHeader("Pragma", "public");
response.setDateHeader("Expires", (System.currentTimeMillis() + MILLISECOND));
}
以下是原理,来自互联网:
2011年 RFC 6266 发布,正式将 Content-Disposition 纳入 HTTP 标准,并再次强调了 RFC 5987
中多语言编码的方法,并给出了一个范例用于解决向后兼容的问题
Content-Disposition : attachment;filename=“encoded_text”;filename*=utf-8’'encoded_text
Firefox 、 Chrome 、 Opera 、 Safari 等浏览器,都支持新标准规定的 filename*,IE支持filename=“encoded_text”
参考资料:
https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Headers/Content-Disposition
https://tools.ietf.org/html/rfc6266
下一篇: MySQL高可用