在写文件下载的时候遇到的一个问题,也就是下载的文件的文件名是中文的话,浏览器下载的时候可能是乱码,解决方案如下:

 

因为从服务器向浏览器发送中文时,需要对内容进行URL编码。
> 大部分浏览器使用如下方式即可解决乱码问题:URLEncoder.encode(fileName, “utf-8”);
> 但是火狐默认以Base64来解码的,所以要为火狐单独处理。
> 可以使用如下代码来判断浏览器的类型,然后进行不同的编码处理
 // 请求客户端操作系统的信息  
	    final String userAgent = request.getHeader("USER-AGENT");  
	    if(userAgent.contains("Firefox")){
			//是火狐浏览器,使用BASE64编码
			fileName = "=?utf-8?b?"+new BASE64Encoder().encode(fileName.getBytes("utf-8"))+"?=";
		}else{
			//给文件名进行URL编码
			//URLEncoder.encode()需要两个参数,第一个参数时要编码的字符串,第二个是编码所采用的字符集
			fileName = URLEncoder.encode(fileName, "utf-8");
		}

然后再去设置响应头,应该就没问题了

 response.setContentType(servletContext.getMimeType(fileName));
response.addHeader("Content-Disposition", "attachment; filename=" + fileName);  
		 
二、还有一种通用的方法,可能简单点,但是如果文件名夹杂个别特殊符号,可能还会乱码,不过对大多数带有特殊符号的中文名还是好使的;
– 向将字符串用gbk进行解码,然后在使用iso8859-1进行编码
fileName = new String(fileName.getBytes(“gbk”),”iso8859-1″);

版权声明:本文为Actexpler-S原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/Actexpler-S/p/7401799.html