1、首先后台接收后,多文件名进行再编码
filePath = new String(filePath.getBytes(),"utf-8");//有没有这句话
2、注意设置浏览器,很重要
//浏览器设置
String userAgent = request.getHeader("User-Agent");
if (userAgent.contains("MSIE") || userAgent.contains("Trident")) {
//IE浏览器处理
fileName = java.net.URLEncoder.encode(fileName, "UTF-8");
} else {
// 非IE浏览器的处理:
fileName = new String(fileName.getBytes("UTF-8"), "ISO-8859-1");
}
// 设置文件头:最后一个参数是设置下载文件名
response.setHeader("Content-Disposition", "attachment;fileName="+fileName);
// 设置文件ContentType类型,这样设置,会自动判断下载文件类型
response.setContentType("application/octet-stream;charset=utf-8");
//流对拷
OutputStream os = response.getOutputStream();
int len = 0;
byte[] b = new byte[1024];
while ((len = is.read(b)) > 0) {
os.write(b, 0, len);
}
os.close();
is.close();
本文介绍了一种处理文件下载时跨浏览器兼容性的方法,包括文件名编码、浏览器识别及响应头设置,确保在IE和其他现代浏览器下都能正确下载文件。
842

被折叠的 条评论
为什么被折叠?



