码迷,mamicode.com
首页 > 其他好文 > 详细

兼容各浏览器的文件下载时中文名称乱码的解决方案

时间:2019-04-12 10:34:02      阅读:140      评论:0      收藏:0      [点我收藏+]

标签:exce   解决   没有   header   public   attach   blog   gen   extends   

public class DownloadServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// codes..
String name = "中文名 带空格 的测试文件.txt";
String userAgent = request.getHeader("User-Agent");
byte[] bytes = userAgent.contains("MSIE") ? name.getBytes() : name.getBytes("UTF-8"); // name.getBytes("UTF-8")处理safari的乱码问题
name = new String(bytes, "ISO-8859-1"); // 各浏览器基本都支持ISO编码
response.setHeader("Content-disposition", String.format("attachment; filename=\"%s\"", name)); // 文件名外的双引号处理firefox的空格截断问题
// codes..
}
}

这段代码处理了文件下载时不同浏览器解析中文文件名所出现的乱码问题和firefox的空格截断问题,在IE9, chrome, opera, safari, firefox下均测试通过。

来源:https://f0rb.iteye.com/blog/1308579

    但是没有解决我的ie9下载时的乱码问题,做了一步修改:

response.addHeader("Content-Disposition", "attachment;filename=" + new String(fileName.getBytes("GBK"),"ISO8859-1"));

  修改为gbk后问题解决。

兼容各浏览器的文件下载时中文名称乱码的解决方案

标签:exce   解决   没有   header   public   attach   blog   gen   extends   

原文地址:https://www.cnblogs.com/wtcadmin/p/10694352.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!