Web文件下载有两种,一种是文件在网站目录下,在浏览器中直接输入文件路径即可下载,如http://www.xxx.com/file.zip。另外一种是文件不在网站目录下或者文件是动态生成的(导出报表或者导出excel等),这种情况需要通过response的OutputStream实现文件的下载。DownloadUtils是一个Java Web文件下载工具类,提供多种静态方法实现文件下载。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
|
package com.rhui.util;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
/**
* 文件下载类
*/
public class DownloadUtils {
/**
* 文件下载编码
* 该编码告诉浏览器文件名的编码方式,以防下载中文文件名时有乱码
*/
private static String encoding = "utf-8" ;
/**
* 文件下载
* @param response
* @param filePath 文件在服务器上的路径,包含文件名
*/
public static void download(HttpServletResponse response, String filePath){
File file = new File(filePath.toString());
download(response, file, null , encoding);
}
/**
* 文件下载
* @param response
* @param filePath 文件在服务器上的路径,包括文件名称
* @param fileName 文件下载到浏览器的名称,如果不想让浏览器下载的文件名称和服务器上的文件名称一样,请设置该参数
*/
public static void download(HttpServletResponse response, String filePath, String fileName){
File file = new File(filePath.toString());
download(response, file, fileName, encoding);
}
/**
* 文件下载
* @param response
* @param filePath 文件在服务器上的路径,包括文件名称
* @param fileName 文件下载到浏览器的名称,如果不想让浏览器下载的文件名称和服务器上的文件名称一样,请设置该参数
* @param encoding 文件名称编码
*/
public static void download(HttpServletResponse response, String filePath, String fileName, String encoding){
File file = new File(filePath.toString());
download(response, file, fileName, encoding);
}
/**
* 文件下载
* @param response
* @param file 文件
* @param fileName 文件下载到浏览器的名称,如果不想让浏览器下载的文件名称和服务器上的文件名称一样,请设置该参数
*/
public static void download(HttpServletResponse response, File file) {
download(response, file, null , encoding);
}
/**
* 文件下载
* @param response
* @param file 文件
* @param fileName 文件下载到浏览器的名称,如果不想让浏览器下载的文件名称和服务器上的文件名称一样,请设置该参数
*/
public static void download(HttpServletResponse response, File file, String fileName) {
download(response, file, fileName, encoding);
}
/**
* 文件下载
* @param response
* @param file 文件
* @param fileName 文件下载到浏览器的名称,如果不想让浏览器下载的文件名称和服务器上的文件名称一样,请设置该参数
* @param encoding 文件名称编码
*/
public static void download(HttpServletResponse response, File file, String fileName, String encoding) {
if (file == null || !file.exists() || file.isDirectory()){
return ;
}
// 如果不指定文件下载到浏览器的名称,则使用文件的默认名称
if (StringUtils.isBlank(fileName)) {
fileName = file.getName();
}
try {
InputStream is = new FileInputStream(file);
download(response, is, fileName, encoding);
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* 文件下载
* @param response
* @param is 文件输入流
* @param fileName 下载的文件名称
* @throws IOException
*/
public static void download(HttpServletResponse response, InputStream is, String fileName){
download(response, is, fileName, encoding);
}
/**
* 文件下载
* @param response
* @param is 文件输入流
* @param fileName 下载的文件名称
* @param encoding 编码格式
*/
public static void download(HttpServletResponse response, InputStream is, String fileName, String encoding){
if (is == null || StringUtils.isBlank(fileName)){
return ;
}
BufferedInputStream bis = null ;
OutputStream os = null ;
BufferedOutputStream bos = null ;
try {
bis = new BufferedInputStream(is);
os = response.getOutputStream();
bos = new BufferedOutputStream(os);
response.setContentType( "application/octet-stream;charset=" + encoding);
response.setCharacterEncoding(encoding);
response.setHeader( "Content-disposition" , "attachment;filename=" + URLEncoder.encode(fileName, encoding));
byte [] buffer = new byte [ 1024 ];
int len = bis.read(buffer);
while (len != - 1 ){
bos.write(buffer, 0 , len);
len = bis.read(buffer);
}
bos.flush();
} catch (IOException e){
e.printStackTrace();
} finally {
if (bis != null ){
try {
bis.close();
} catch (IOException e){}
}
if (is != null ){
try {
is.close();
} catch (IOException e){}
}
}
}
public static String getEncoding() {
return encoding;
}
public static void setEncoding(String encoding) {
DownloadUtils.encoding = encoding;
}
}
|
如果文件保存在服务器的非网站目录下
1
2
|
String filePath = "c:\\file.zip" ;
DownloadUtils.download(response, filePath);
|
如果文件是输入流
1
2
3
4
5
6
|
// is为文件输入流
// fileName为浏览器下载的文件名称
// encoding为文件名称编码,预防文件中有中文的时候产生乱码
String fileName = "file.zip" ;
String encoding = "utf-8" ;
DownloadUtils.download(response, is, fileName, encoding);
|
Servlet中文件下载
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
package com.rhui.web.servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.rhui.util.DownloadUtils;
@WebServlet ( "/download/servlet" )
public class DownloadServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String filePath = "c:\\file.zip" ;
DownloadUtils.download(response, filePath);
}
}
|
PS:图片下载(含防盗链功能)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
package cn.itcast.day06.web.servlet;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class DownloadServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// 实现防盗链功能
// 获得 referer 头 用于说明来访者来自哪里
String referer = request.getHeader( "referer" );
if (referer== null || !referer.startsWith( "http://localhost" )) {
// 是盗链者
response.sendRedirect( "/day06/index.jsp" );
return ;
}
// 解决response中文乱码问题
response.setContentType( "text/html;charset=utf-8" ); // 设置消息体的编码
// 通过 http 协议 发送的http响应消息头 不能出现中文 中文必须要经过url编码
String filename = URLEncoder.encode( "美女.jpg" , "utf-8" );
// 通知浏览器以下载的方式读取资源
response.setHeader( "content-disposition" , "attachment;filename=" +filename);
// 读取图片数据 发给ie浏览器
String webPath = "/download/美女.jpg" ; // 相当于当前web应用的path
ServletContext servletContext = super .getServletContext();
InputStream in = servletContext.getResourceAsStream(webPath);
OutputStream out = response.getOutputStream();
int len;
byte [] buffer = new byte [ 1024 ];
while ((len=in.read(buffer))!=- 1 )
out.write(buffer, 0 , len);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
|