文件下载
步骤:
- 获取要下载的文件名
- 读取要下载的文件内容
- 把下载的文件回传给客户端
- 在回传前,通过响应头告诉客户端返回的数据类型
- 还要告诉客户端收到的数据是用于下载
代码:
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 1. 获取要下载的文件名
String name = "da.jpg";
// 2. 读取要下载的文件内容
ServletContext servletContext = getServletContext();
// 获取要下载的文件的类型
// web目录下的file目录下的da.jpg
String mimeType = servletContext.getMimeType("/file/" + name);
// 4. 在回传前,通过响应头告诉客户端返回的数据类型
resp.setContentType(mimeType);
// 5. 还要告诉客户端收到的数据是用于下载
// Content-Disposition响应头,表示收到的数据怎么处理
// atachment 表示附件,下载使用
// filename = 下载的文件名
resp.setHeader("Content-Disposition","attachment;file="+name);
// 3. 把下载的文件回传给客户端
//获取响应的输出流和输出流
InputStream resourceAsStream = servletContext.getResourceAsStream("/file/"+name);
OutputStream outputStream = resp.getOutputStream();
// 将resourceAsStream复制给outputStream,输出给客户端
IOUtils.copy(resourceAsStream, outputStream);
}
如果使用谷歌或ie浏览器下载文件名为中文的文件,需要使用URLEncoder,否则文件名是乱码
代码:
resp.setHeader("Content-Disposition","attachment;file="+ URLEncoder.encode(name, "utf-8"));
火狐浏览器是用的是Base64编码,所以:
resp.setHeader("Content-Disposition","attachment;file==?UTF-8?B?"+new BASE64Encoder().encode(name.getBytes("UTF-8"))+"?=");
使用User-Agent请求头动态切换:
if (resp.getHeader("User-Agent").contains("Firefox")){
resp.setHeader("Content-Disposition","attachment;file==?UTF-8?B?"+new BASE64Encoder().encode(name.getBytes("UTF-8"))+"?=");
}else {
resp.setHeader("Content-Disposition","attachment;file="+ URLEncoder.encode(name, "utf-8"));
}
("Content-Disposition","attachment;file="+ URLEncoder.encode(name, "utf-8"));
}