文件下载-文件名中文在IE10以上浏览器乱码问题解决
前端中文转码
前端页面对中文进行二次转码,即encodeURIComponent(encodeURIComponent(‘中国’)),"中国"转码后变成%25E4%25B8%25AD%25E5%259B%25BD,然后把url连接字符串上把中文替换成转码后的字符,
原来地址:http://localhost/download?fileName=中国
转换后地址:http://localhost/download?fileName=%25E5%258F%2591%25E7%25A5%25A8%25E9%2587%2587%25E9%259B%2586%25E5%2588%2597%25E8%25A1%25A8。
后端转码
后端解码的方式很多,但通过最佳实践,只有通过URLEncoder.decode()解码最有效:
- 先对前端传递过来的文件名进行解码,URLDecoder.decode(fileName, “UTF-8”);
- 然后在response的header上设置导出的文件名,这个文件名可以通过URLEncoder编码解决,即URLEncoder.encode(fileName,“UTF-8”),否则在IE10以上浏览器文件名是乱码
- 在tomcat配置文件server.xml连接节点上增加UTF-8字符集,即:
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" />
本文在IE11上测试没有问题,其他版本期待你的验证。