Java附件下载时中文字符乱码的处理

做附件下载时,一般如此实现:

out = response.getOutputStream();
response.reset();

response.setHeader("Content-Disposition", "attachment;filename=" + browName);
 response.setContentType(contentType);
 byte[] fileByte = new byte[1024];
 while (fileInputStream.read(fileByte) > 0){
   out.write(fileByte, 0, fileByte.length);
 }
  out.flush();
  out.close();
  out = null;

 

如果文件名是中文,下载显示乱码,一般使用browName=java.net.URLEncoder.encode(realFileName, "UTF-8")编码处理,此方式在FF下显示乱码,在IE下如果文件名长则不能直接打开。

于是想到了RFC2047编码,但IE又下不支持RFC2047,但可以变通,判断客户端类型解决;

问题又出现:使用RFC2047编码,如果文件名长,则出现换行(根据RFC822规定,每76个字符,还需要加上一个回车换行。),所以还要处理换行符。

 

综合解决方式是:

 

String browName = "=?UTF-8?B?" + new String(Base64.encode(realFileName.getBytes("UTF-8")))  + "?=";

//处理换行符(如果存在)
      StringReader sr = new StringReader(browName);
      BufferedReader br = new BufferedReader(sr);
      String line = null;
      String temp = "";
      while((line=br.readLine())!=null){
          temp += line;
      }
      browName = temp;
//如果是IE
      String clientInfo = request.getHeader("User-agent");
      if(clientInfo != null && clientInfo.indexOf("MSIE") > 0 ){//IE采用URLEncoder方式处理
       if(clientInfo.indexOf("MSIE 6") > 0 || clientInfo.indexOf("MSIE 5") > 0){//IE6,用GBK,此处实现由局限性
        browName = new String(realFileName.getBytes("GBK"),"ISO-8859-1");
       }else{//ie7+用URLEncoder方式
        browName = java.net.URLEncoder.encode(realFileName, "UTF-8");
       }
      }

 

 response.setHeader("Content-Disposition",
        "attachment;filename=" + browName);

 

解决!

 

。。。。

 

 此实现方式 如果在IE5、6下查看非中文、非英文的附件名还是会出现乱码,涉及国际化时应注意,

但基本能满足国人处理中文附件名的问题。

在IE5、6下想不出解决方式了,谁有解决方案请跟贴!

 

 

 

 

 

你可能感兴趣的:(java,.net,IE)