Servlet下载中出现中文乱码以及文件名不全的解决方法

出现这个问题的主要原因就是不同浏览器提供的解析编码不同

IE和谷歌用的是URL编码,而火狐用的是Base64编码

解决问题的方法就是根据不同的浏览器设置响应的编码

// 先从request中获取浏览器的信息

String agent = request.getHeader("User-Agent");

// 判断是什么浏览器
if(agent.contains("Firefox")){
    // 如果是火狐浏览器,使用Base64编码
    filename = DownloadUtil.base64EncodeFileName(filename);
 }else{
      // IE或者谷歌的浏览器 URL编码
     filename = URLEncoder.encode(filename, "UTF-8");
     // 在IE浏览器下载时会出现空格变成 + 的问题,所以这里把空+编码成空格
     filename = filename.replace("+", " ");

 }

由于火狐浏览器的解析比较繁琐,所以将解析放在一个方法里,使用者直接调用即可

import sun.misc.BASE64Encoder;

public class DownloadUtil {
    public static String base64EncodeFileName(String filename) {
        BASE64Encoder base64Encoder = new BASE64Encoder();
        try {
            return "=?UTF-8?B?"
                    + new String(base64Encoder.encode(filename
                            .getBytes("UTF-8"))) + "?=";
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }
    }
}

注意:直接复制方法可能会出现导包不成功

解决方法:在 jre目录下找到rt.jar包,导入项目lib目录即可

jar包路径:Java\jre8\lib\rt.jar

猜你喜欢

转载自blog.csdn.net/jee0520/article/details/80532237
今日推荐