下载文件时文件名中文乱码问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/cccmercy/article/details/83062593

通过User-Agent请求头判断当前浏览器类型

  • Chrome
    • Chrome:User-Agen中含有"Chrome"字符串
    • User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36
    • 解决方式:fileName = new String(fileName .getBytes("UTF-8"), "ISO8859-1");
  • IE
    • IE浏览器:User-Agent中含有"Trident"字符串
    • User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko
    • 解决方式:fileName = URLEncoder.encode(fileName, "UTF-8").replace("+", "%20");
  • Firefox
    • Firefox:User-Agent中含有"Firefox"字符串
    • User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:56.0) Gecko/20100101 Firefox/56.0
    • 解决方式:fileName = "=?utf-8?b?"+new BASE64Encoder().encode(fileName .getBytes("utf-8"))+"?=";
  • Edge
    • Edge:User-Agent中含有"Edge"字符串
    • User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36 Edge/15.15063
    • 解决方式:fileName = URLEncoder.encode(fileName, "UTF-8").replace("+", "%20");
  • 其他浏览器
    • 解决方式(仍然存在部分中文乱码问题):fileName = new String(fileName .getBytes("gbk"),"ISO8859-1");

getBytes(String charsetName): 使用指定的字符集将字符串编码为 byte 序列,并将结果存储到一个新的 byte 数组中。

new String(byte[], decode):使用指定的编码 decode 来将 byte[] 解析成字符串。

模板代码:

String fileName = "盗将行.mp3";
String userAgent = request.getHeader("User-Agent");
if ("Edge".contains(userAgent)) {
 	fileName = URLEncoder.encode(fileName, "UTF-8").replace("+", "%20");
}else if ("Chrome".contains(userAgent)) {
 	fileName = new String(fileName.getBytes("UTF-8"), "ISO8859-1");
}else if ("Firefox".contains(userAgent)) {
 	fileName = "=?utf-8?b?"+new BASE64Encoder().encode(fileName.getBytes("utf-8"))+"?=";
}else if ("Trident".contains(userAgent)) {
 	fileName = URLEncoder.encode(fileName, "UTF-8").replace("+", "%20");
}else {
 	fileName = new String(fileName.getBytes("gbk"),"ISO8859-1");
}

猜你喜欢

转载自blog.csdn.net/cccmercy/article/details/83062593