问题描述:本地windows中tomcat下使用Servlet实现文件下载功能时,使用IE浏览器下载出现文件名乱码
解决办法:判断当前浏览器属于哪一种类型的浏览器
注意的是:在Windows 10 中 用户代理字符串已经修改了,不在是“mise”。
- 兼容("兼容")和浏览器 ("MSIE") 令牌已删除。
- "like Gecko" 令牌已添加(以便与其他浏览器一致)。
- 浏览器版本现在由新版本 ("rv") 令牌报告。
String userAgent = req.getHeader("user-agent").toLowerCase();
if (userAgent.contains("msie") || userAgent.contains("like gecko") ) {
// win10 ie edge 浏览器 和其他系统的ie浏览器
fileName = URLEncoder.encode(fileName, "UTF-8");
} else {
// 非ie浏览器
fileName = new String(fileName.getBytes("UTF-8"), "iso-8859-1");
}
问题描述:Linux服务器中的tomcat下使用Servlet实现文件下载功能时,使用IE浏览器下载出现文件名乱码
解决办法:
String userAgent = httpServletRequest.getHeader("user-agent").toLowerCase();
if (userAgent.contains("msie") || userAgent.contains("like gecko") ) {
fileName = URLEncoder.encode(fileName, "iso8859-1");
}
本文介绍在Windows和Linux环境下,使用Tomcat与Servlet实现文件下载时,针对IE浏览器出现的文件名乱码问题的解决方案。通过判断浏览器类型,采用不同的编码方式,确保跨平台下载时文件名正确显示。
976

被折叠的 条评论
为什么被折叠?



