FIREFOX 下载中文文件名出现乱码的java解决方案

[java] view plain copy
 
 在CODE上查看代码片派生到我的代码片
  1. private void setHeader(HttpServletResponse response,  
  2.             HttpServletRequest request, String filename)  
  3.             throws UnsupportedEncodingException {  
  4.         response.reset();  
  5.         // 设置为下载application/x-download  
  6.         response.setContentType("application/x-download charset=UTF-8");  
  7.         // 通常解决汉字乱码方法用URLEncoder.encode(...)  
  8.         String filenamedisplay = URLEncoder.encode(filename, "UTF-8") + ".pdf";  
  9.         if ("FF".equals(getBrowser(request))) {  
  10.             // 针对火狐浏览器处理方式不一样了  
  11.             filenamedisplay = new String(filename.getBytes("UTF-8"),  
  12.                     "iso-8859-1") + ".pdf";  
  13.         }  
  14.         response.setHeader("Content-Disposition", "attachment;filename="  
  15.                 + filenamedisplay);  
  16.     }  
  17.   
  18.     // 以下为服务器端判断客户端浏览器类型的方法  
  19.     private String getBrowser(HttpServletRequest request) {  
  20.         String UserAgent = request.getHeader("USER-AGENT").toLowerCase();  
  21.         if (UserAgent != null) {  
  22.             if (UserAgent.indexOf("msie") >= 0)  
  23.                 return "IE";  
  24.             if (UserAgent.indexOf("firefox") >= 0)  
  25.                 return "FF";  
  26.             if (UserAgent.indexOf("safari") >= 0)  
  27.                 return "SF";  
  28.         }  
  29.         return null;  
  30.     }  
posted @ 2016-11-30 14:32  DearBelinda  阅读(437)  评论(0编辑  收藏  举报