乱码的原因是什么?
每个浏览器的编码不一样,火狐采用的是base64.ie和谷歌采用的是url编码

所以我们在设置响应头的时候
Content-Type getServletContext().getMineType(filename);
Content-Disposition accachment;filename=编码后的filename

url编码
name = URLEncoder.encode(filename, "UTF-8");

base64编码
/**

  • 传入文件的名称,进行Base64编码
  • @param fileName
  • @return
    */
    public 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);
      }
      }