Web文件下载有两种,一种是文件在网站目录下,在浏览器中直接输入文件路径即可下载,如http://www.xxx.com/file.zip。另外一种是文件不在网站目录下或者文件是动态生成的(导出报表或者导出excel等),这种情况需要通过response的OutputStream实现文件的下载。DownloadUtils是一个Java Web文件下载工具类,提供多种静态方法实现文件下载。
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; } }
如果文件保存在服务器的非网站目录下
String filePath = "c:\\file.zip"; DownloadUtils.download(response, filePath);
如果文件是输入流
// is为文件输入流 // fileName为浏览器下载的文件名称 // encoding为文件名称编码,预防文件中有中文的时候产生乱码 String fileName = "file.zip"; String encoding = "utf-8"; DownloadUtils.download(response, is, fileName, encoding);
Servlet中文件下载
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:图片下载(含防盗链功能)
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); } }
本文向大家介绍javaweb实现文件上传与下载功能,包括了javaweb实现文件上传与下载功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了javaweb文件的上传与下载,供大家参考,具体内容如下 一、文件上传 要实现Web开发的上传功能,通常需要完成两步操作:一是在Web页面中添加上传输入项;二是在Servlet中读取上传文件的数据,并保存到本地硬盘中。 上传大多数情况是通过表单
本文向大家介绍C#实现多线程下载文件的方法,包括了C#实现多线程下载文件的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现多线程下载文件的方法。分享给大家供大家参考。具体实现方法如下: 调用: 希望本文所述对大家的C#程序设计有所帮助。
本文向大家介绍JavaWeb实现文件上传与下载实例详解,包括了JavaWeb实现文件上传与下载实例详解的使用技巧和注意事项,需要的朋友参考一下 在Web应用程序开发中,文件上传与下载功能是非常常用的功能,下面通过本文给大家介绍JavaWeb实现文件上传与下载实例详解。 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用Servlet获取上传文件的输入流然后再解析里
本文向大家介绍jsp实现Servlet文件下载的方法,包括了jsp实现Servlet文件下载的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jsp实现Servlet文件下载的方法。分享给大家供大家参考。具体如下: 希望本文所述对大家的JSP程序设计有所帮助。
本文向大家介绍C#实现HTTP下载文件的方法,包括了C#实现HTTP下载文件的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现HTTP下载文件的方法。分享给大家供大家参考。 主要实现代码如下: 希望本文所述对大家的C#程序设计有所帮助。
本文向大家介绍javaweb页面附件、图片下载及打开(实现方法),包括了javaweb页面附件、图片下载及打开(实现方法)的使用技巧和注意事项,需要的朋友参考一下 在javaweb中写了一个图片的链接,可以打开预览,另外提供一个下载功能。 以下是预览代码,没什么好说的;href若连接的是一个压缩包文件之类无法直接打开的就可以直接下载; 关键在于如何在页面上下载这个张图片,于是写了下面的一个jsp用