1.首先struts2.xml 里面
<action name="download" class="com.zfj.action.DownloadAction">
<!-- 注意这里不再是返回一个字符串找到一尺巧个页面了
从服务器返回到本地客户端是一个流 我们需要配置流信息
默认是 dispatcher 请求转发,所以之前我们一般不书写这个参数但是这里需要更改为stream重定向
-->陵悄键
<result type="stream">
<!--
因为之前我们设置的execute方法返回一个String,但是我们现在运辩需要返回一个流。这里我们要指定一个新的方法为我们处理业务逻
辑并且返回流所以默认execute 方法对我们没有作用了,在这里我们指定一个新的方法为我们处理业务逻辑并且最后返回流
这里的inputName是固定写法 后面的名字dname要跟 action里面的getDname对应
-->
<param name="inputName">dname</param>
<!-- 当流返回过来时,我们应当设置头信息
给浏览器,这里设置的都是流信息
name里面的是固定写法
attachment:表示使用附件下载
online:直接打开
分号后的filename是固定写法,后面通过一个ognl表达式
引用下载的文件名
-->
<param name="contentDisposition">attachmentfilename=${filename}</param>
</result>
</action>
这里不再是返回一个字符串找到一个页面了。从服务器返回到本地客户端是一个流,我们需要配置流信息。
type:表示接受方式或者跳转方式是(默认是dispathcher请求转发,所以之前我们一般不书写这个,但是这里下载需要更改stream)
2.对应的DownloadAction
@Override
public String execute() throws Exception {
return this.SUCCESS
}
//这里的getEtoak要跟struts.xml里的inputName的值对应
public InputStream getEtoak() throws Exception {
return new FileInputStream(
ServletActionContext.getServletContext()
.getRealPath("/image")
+ "/"
+ this.getFilename())
}
参考下面public HttpServletResponse download(String path, HttpServletResponse response) {
try {
// path是指欲下载的文件的路径。
File file = new File(path)
// 取得文件名。
String filename = file.getName()
// 取得文件的后缀名。
String ext = filename.substring(filename.lastIndexOf(".") + 1).toUpperCase()
// 以流的形式下载文件。
InputStream fis = new BufferedInputStream(new FileInputStream(path))
byte[] buffer = new byte[fis.available()]
fis.read(buffer)
fis.close()
// 清空response
response.reset()
// 设置response的Header
response.addHeader("Content-Disposition", "attachmentfilename=" + new String(filename.getBytes()))
response.addHeader("Content-Length", "" + file.length())
OutputStream toClient = new BufferedOutputStream(response.getOutputStream())
response.setContentType("application/octet-stream")
toClient.write(buffer)
toClient.flush()
toClient.close()
} catch (IOException ex) {
ex.printStackTrace()
}
return response
}
// 下载本地文件
public void downloadLocal(HttpServletResponse response) throws FileNotFoundException {
String fileName = "Operator.doc".toString()// 文件的默认保存名
// 读到流中
InputStream inStream = new FileInputStream("c:/Operator.doc")// 文件的存放路径
// 设置输出的格式
response.reset()
response.setContentType("bin")
response.addHeader("Content-Disposition", "attachmentfilename=\"" + fileName + "\"雹肆")
// 循环取出流中的数据
byte[] b = new byte[100]
int len
try {
while ((len = inStream.read(b)) >0)
response.getOutputStream().write(b, 0, len)
inStream.close()
} catch (IOException e) {
e.printStackTrace()
}
}
// 下载网络文件
public void downloadNet(HttpServletResponse response) throws MalformedURLException {
int bytesum = 0
int byteread = 0
URL url = new URL("windine.blogdriver.com/源念轿logo.gif")
try {
URLConnection conn = url.openConnection()
InputStream inStream = conn.getInputStream()
FileOutputStream fs = new FileOutputStream("c:/abc.gif"高局)
byte[] buffer = new byte[1204]
int length
while ((byteread = inStream.read(buffer)) != -1) {
bytesum += byteread
System.out.println(bytesum)
fs.write(buffer, 0, byteread)
}
} catch (FileNotFoundException e) {
e.printStackTrace()
} catch (IOException e) {
e.printStackTrace()
}
}
//支持在线打开文件的一种方式
public void downLoad(String filePath, HttpServletResponse response, boolean isOnLine) throws Exception {
File f = new File(filePath)
if (!f.exists()) {
response.sendError(404, "File not found!")
return
}
BufferedInputStream br = new BufferedInputStream(new FileInputStream(f))
byte[] buf = new byte[1024]
int len = 0
response.reset()// 非常重要
if (isOnLine) { // 在线打开方式
URL u = new URL("file:///" + filePath)
response.setContentType(u.openConnection().getContentType())
response.setHeader("Content-Disposition", "inlinefilename=" + f.getName())
// 文件名应该编码成UTF-8
} else { // 纯下载方式
response.setContentType("application/x-msdownload")
response.setHeader("Content-Disposition", "attachmentfilename=" + f.getName())
}
OutputStream out = response.getOutputStream()
while ((len = br.read(buf)) >0)
out.write(buf, 0, len)
br.close()
out.close()
}
在jsp/servlet中断点/多线程下载文件
<%@ page import="java.io.File" %><%@ page import="java.io.IOException" %>
<%@ page import="兄迹燃java.io.OutputStream" %>
<%@ page import="java.io.RandomAccessFile" %>
<%!
public void downloadFile(HttpServletRequest request, HttpServletResponse response, File file) throws IOException {
RandomAccessFile raf = new RandomAccessFile(file, "r")
java.io.FileInputStream fis = new java.io.FileInputStream(raf.getFD())
response.setHeader("Server", "www.trydone.com")
response.setHeader("Accept-Ranges", "bytes")
long pos = 0
long len
len = raf.length()
if (request.getHeader("Range") != null) {
response.setStatus(HttpServletResponse.SC_PARTIAL_CONTENT)
pos = Long.parseLong(request.getHeader("Range")
羡虚 .replaceAll("bytes=", "")
.replaceAll("-", "")
)
}
response.setHeader("Content-Length", Long.toString(len - pos))
if (pos != 0) {
response.setHeader("Content-Range", new StringBuffer()
.append("bytes ")
.append(pos)
.append("-")
.append(Long.toString(len - 1))
.append("/")
.append(len)
州扰 .toString()
)
}
response.setContentType("application/octet-stream")
response.setHeader("Content-Disposition", new StringBuffer()
.append("attachmentfilename=\"")
.append(file.getName())
.append("\"").toString())
raf.seek(pos)
byte[] b = new byte[2048]
int i
OutputStream outs = response.getOutputStream()
while ((i = raf.read(b)) != -1) {
outs.write(b, 0, i)
}
raf.close()
fis.close()
}
%>
<%
String filePath = request.getParameter("file")
filePath = application.getRealPath(filePath)
File file = new File(filePath)
downloadFile(request, response, file)
%>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)