JAVA文件下载时乱码有两种状况:java
1,下载时中文文件名乱码浏览器
2,下载时由于路径中包含中文文件名乱码,提示找不到文件tomcat
解决方法见下面部分代码app
response.setContentType("multipart/form-data");
String userAgent = request.getHeader("User-Agent");
String oraFileName = meetingFile.getFileName();
String formFileName=oraFileName;
// 针对IE或者以IE为内核的浏览器:
if (userAgent.contains("MSIE") || userAgent.contains("Trident")) {
formFileName = java.net.URLEncoder.encode(formFileName, "UTF-8");
} else {
// 非IE浏览器的处理:
formFileName = new String(formFileName.getBytes("UTF-8"), "ISO-8859-1");
}
response.setHeader("Content-disposition",
String.format("attachment; filename=\"%s\"", formFileName));
response.setContentType("application/vnd.ms-excel;charset=utf-8");
response.setCharacterEncoding("UTF-8");
ServletOutputStream out;
// 经过文件路径得到File对象
File file = null;
if (meetingFile != null) {
file = new File(path + "upload/"+oraFileName);
}
(1)若是第一种乱码类型,下载页面遇到如下的中文乱码问题eclipse
用如下代码解决ide
(2)若是下载遇到第二种乱码问题,如图:测试
用如下代码解决:即首先确保tomcat ,eclipse等为utf-8编码编码
而后JAVA中这样与第一种对文件名编码分开,使它们分别编码,互不影响。spa
注意:之前目前测试可解决火狐与IE等浏览器下载时的编码问题,而针对WIN10自带的浏览器不时仍会出现乱码现象.net