先上一段源代码,这一段文件下载,是在 Servlet 上面实现的。
package util;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class DownloadServlet
*/
@WebServlet("/DownloadServlet")
public class DownloadServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public DownloadServlet() {
super();
// TODO Auto-generated constructor stub
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//得到要下载的文件名 通过 request对象的方法
String fileName = request.getParameter("filename");
//处理文件名的中文乱码问题
fileName = new String(fileName.getBytes("ISO-8859-1"),"UTF-8");
//下载的文件都是保存在/WEB-INF/upload目录当中
String fileSaveRootPath=this.getServletContext().getRealPath("/WEB-INF/upload");
System.out.println(fileSaveRootPath);
//得到要下载的文件
File file = new File(fileSaveRootPath + "\\" + fileName);
System.out.println(fileSaveRootPath + "\\" + fileName);
//如果文件不存在
if(!file.exists()){
request.setAttribute("msg", "您要下载的资源已被删除!!");
request.getRequestDispatcher("/message.jsp").forward(request, response);
return;
}
//处理文件名
String realname = fileName.substring(fileName.indexOf("_")+1);
//设置响应头,控制浏览器下载该文件
response.setHeader("content-disposition", "attachment;filename=" + URLEncoder.encode(realname, "UTF-8"));
//读取要下载的文件,保存到文件输入流
FileInputStream in = new FileInputStream(file);
//创建输出流
OutputStream out = response.getOutputStream();
//创建缓冲区
byte buffer[] = new byte[1024];
int len = 0;
//循环将输入流中的内容读取到缓冲区当中
while((len=in.read(buffer))>0){
//输出缓冲区的内容到浏览器,实现文件下载
out.write(buffer, 0, len);
}
//关闭文件输入流
in.close();
//关闭输出流
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
下面来总结一下:
文件下载在web开发当中是一个经常用到功能,在Servlet当中实现文件下载的功能有以下步骤.一般情况都是浏览器端发出下载的请求,然后将请求发给服务器端处理。通过上面的代码,可以总结出文件下载的步骤:
1.首先获取浏览器端发来的请求,也就是要获取下载文件的文件名(getParameter(“”filename“”))
2.获取文件的绝对路径(this.getServletContext().getRealPath("/WEB-INF/upload"))
3.设置浏览器的响应头content-disposition 控制浏览器以下载的形式打开文件
4.获取下载文件的输入流(之前判断一下这个文件是否存在)
5.然后通过response 创建输出流outputStream
6.创建缓冲区,然后将循环将输入流当中的数据读到缓冲区
7.通过输出流outputStream 将缓冲区的数据输出到浏览器端
8.最后就是关闭资源
最有就是如果下载的是中文文件的话 需要改变编码,不然会产生乱码 。可以通过(URLEncoder.encode(fileName, "字符编码"))
为什么用outputStream输出流 而不用 PrintWriter 。主要是因为 outputStream 是字节的输出流。 可以处理任意数据 而PrintWriter是字符的输出流 。所以
转自:https://blog.csdn.net/baidu_36697353/article/details/54631540