首先是html页面代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h2>请点击进行文件的下载</h2>
<h3>超链接的下载</h3>
<a href="/Servlet/download/aaa.txt">aaa.txt</a><br/>
<a href="/Servlet/download/E75A8555.JPG">E75A8555.JPG</a><br/>
<a href="/Servlet/download/E75A8690.JPG">E75A8690.JPG</a><br/>
<a href="/Servlet/download/zhcx.rar">zhcx.rar</a><br/>
<h3>手动编码方式下载</h3>
<a href="/Servlet/DownloadServlet?filename=aaa.txt">aaa.txt</a><br/>
<a href="/Servlet/DownloadServlet?filename=美女.JPG">美女.JPG</a><br/>
<a href="/Servlet/DownloadServlet?filename=E75A8690.JPG">E75A8690.JPG</a><br/>
<a href="/Servlet/DownloadServlet?filename=zhcx.rar">zhcx.rar</a><br/>
</body>
</html>
可以清晰的看到在手动编码方式下载过程中是有一个中文名的文件,但是在下载过程中我们要解决两个方面,则不会出现下载时中文名变成乱码
1、当我们将文件名从html传到servlet的时候这时候以get的方式会接受到乱码,所以我们在接收参数的时候应该这样写
String filename=new String(request.getParameter("filename").getBytes("ISO-8859-1"),"UTF-8");
这样的话我们接收的就是中文
2、根据不同的浏览器要进行不同的操作,故我们应该先检查一下浏览器的类型代码如下:
//根据浏览器的类型处理中文文件的乱码问题:
String agent=request.getHeader("User-Agent");
if(agent.contains("Firefox")){
filename=base64EncodeFileName(filename);
}else{
filename=URLEncoder.encode(filename,"UTF-8");
}
只要满足以上两点,则下载时中文名便不会出现乱码的现象。
完整的Servlet代码如下,需要的小伙伴可以自行参考:
package download;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import sun.misc.BASE64Encoder;
/**
* 文件下载的编写
*/
public class DownloadServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.接收参数
String filename=new String(request.getParameter("filename").getBytes("ISO-8859-1"),"UTF-8");
//2完成文件下载(设置Content-Type头、设置Content-Disposition头、设置文件的InputStream)
//2.1设置Content-Type头
String type=this.getServletContext().getMimeType(filename);
response.setHeader("Content-Type", type);
//2.3设置文件的InputStream
String realPath=this.getServletContext().getRealPath("/download/"+filename);
//根据浏览器的类型处理中文文件的乱码问题:
String agent=request.getHeader("User-Agent");
if(agent.contains("Firefox")){
filename=base64EncodeFileName(filename);
}else{
filename=URLEncoder.encode(filename,"UTF-8");
}
//2.2设置Content-Disposition头
response.setHeader("Content-Disposition", "attachment;filename="+filename);
InputStream is=new FileInputStream(realPath);
//获得response的输出流
OutputStream os=response.getOutputStream();
int len=0;
byte[]b=new byte[1024];
while((len=is.read(b))!=-1){
os.write(b, 0, len);
}
is.close();
}
public static 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);
}
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}