乱码的原因是什么? 每个浏览器的编码不一样,火狐采用的是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); } }