javaweb之response实现文件下载(文件名是中文名需要经过url编码)

package test.response;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

//response实现文件下载,文件在WebRoot下的download目录下
public class ResponseDemo2 extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		// 要实现文件下载,首先要获取到被下载的资源,也就是在servlet中读取资源
		// 并且要读取到资源的名称,所以要用servletContext对象得到资源的绝对路径
		String path = this.getServletContext().getRealPath("/download/1.jpg");
		// 得到文件名,如果是中文的文件名需要经过url编码
		// String filename = path.substring(path.lastIndexOf("\\") +
		// 1);//文件名是1.jpg
		String filename = path.substring(path.lastIndexOf("\\") + 1);// 文件名是中文.jpg

		// 输出下载的响应头,如果下载的文件是中文名,文件名需要经过url编码URLEncoder.encode(filename, "UTF-8")
		// response.setHeader("content-disposition", "attachment;filename=" +
		// filename);
		response.setHeader("content-disposition", "attachment;filename="
				+ URLEncoder.encode(filename, "UTF-8"));

		// 创建读取文件的流
		InputStream in = new FileInputStream(path);
		// 创建输出文件的流,也就是response的OutputStream
		OutputStream out = response.getOutputStream();
		// 进行读取并写出,是以前学习io的模版代码
		byte[] buffer = new byte[1024];
		int len = 0;
		while ((len = in.read(buffer)) > 0) {
			out.write(buffer, 0, len);
		}
		in.close();
		out.close();
		// 上面的读取和输出的代码写完了并不管作用,那么样只是单纯的读取和输出,是不能实现文件下载的,想要实现文件下载,还要先向浏览器输出一个响应头
		// response.setHeader("content-disposition", "attachment;filename="+
		// filename);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

你可能感兴趣的:(自己用)