欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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