通过java实现文件下载

通过java实现文件下载,第1张

在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)%>

是否可以解决您的问题?

参考下面

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()

}

我用struts2给你实现:

1.首先struts2.xml 里面

<action name="download" class="com.zfj.action.DownloadAction">

<!-- 注意这里不再是返回一个字符串找到一个页面了

从服务器返回到本地客户端是一个流 我们需要配置流信息

type:表示接受方式或者跳转方法

默认是 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())

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11493726.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存