本文实例讲述了jsp实现Servlet文件下载的方法。分享给大家供大家参考。具体如下:
package com; import java.io.IOException; import java.io.PrintWriter; import java.net.URLEncoder; import java.util.Date; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeUtility; /** * 文件下载类。为了防止客户端浏览器直接打开目标文件(例如在装了MS Office套件的Windows中的IE浏览器可能就会直接在IE浏览器中打开你想下载的doc或者xls文件),在响应头里加入强制下载的MIME类型。 */ public class DownloadFile extends HttpServlet { private static final Log log = LogFactory.getLog(DownloadFile.class); public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException { long timeStart = 0; if(log.isDebugEnabled()){ timeStart=System.currentTimeMillis(); } response.setContentType("application/x-download charset=UTF-8"); java.io.FileInputStream fis = null; String filepath = request.getRealPath(""); javax.servlet.ServletOutputStream sos = null; // System.out.println("DownloadFile filename:" + filename); try { if(request.getParameter("filename")==null ||request.getParameter("showName")==null){ return; } String filename = request.getParameter("filename"); String showName = request.getParameter("showName"); request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("UTF-8"); java.io.File file = new java.io.File(filepath + filename); if (!file.exists()) { log.error(file.getAbsolutePath() + " 文件不存在!"); return; } // 读取文件流 fis = new java.io.FileInputStream(file); // 设置下载保存的文件名 sos = response.getOutputStream(); showName += filename.substring(filename.lastIndexOf(".")); String contentDisposition = "", browser = getBrowser(request); if ("IE".equals(browser)) { contentDisposition = "attachment; filename=" + URLEncoder.encode(showName, "UTF-8").replace("+", "%20"); } else if ("CH".equals(browser)) { contentDisposition = "attachment; filename=" + MimeUtility.encodeText(showName, "UTF8", "B"); } else if ("SF".equals(browser)) { contentDisposition = "attachment; filename=" + new String(showName.getBytes("UTF-8"), "ISO8859-1"); } else { contentDisposition = "attachment; filename*=UTF-8''" + URLEncoder.encode(showName, "UTF-8").replace("+", "%20"); } response.setHeader("Content-Disposition", contentDisposition); int byteCount = 0; if (fis != null) { byte[] buff = new byte[1024]; int bytesRead; while(-1 != (bytesRead = fis.read(buff, 0, buff.length))) { sos.write(buff, 0, bytesRead); sos.flush(); byteCount += bytesRead; } } sos.flush(); if(log.isDebugEnabled()){ log.debug("文件下载完成,文件大小:"+ byteCount +",总共用时:"+ (new Date().getTime() - timeStart) +"毫秒。"); } } catch(IOException ioe) { ioe.printStackTrace(); } finally { try { if(fis!=null){ fis.close(); } } catch (IOException e) { } finally { try { if(sos!=null){ sos.close(); } } catch (IOException e) { } } } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); PrintWriter out = response.getWriter(); out.println("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">"); out.println("<html>"); out.println(" <head>"); out.println(" <title>文件下载</title>"); out.println(" <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\" />"); out.println(" </head>"); out.println(" <body>"); out.print(" This is "); out.print(this.getClass().getName()); out.println(", using the POST method"); out.println(" </body>"); out.println("</html>"); out.flush(); out.close(); } private String getBrowser(HttpServletRequest request) { String userAgent = request.getHeader("USER-AGENT").toLowerCase(); if (userAgent != null) { if (userAgent.indexOf("msie") >= 0) { return "IE"; } else if (userAgent.indexOf("mozilla") >= 0) { return "FF"; } else if (userAgent.indexOf("applewebkit") >= 0) { return "CH"; } else if (userAgent.indexOf("safari") >= 0) { return "SF"; } else if (userAgent.indexOf("opera") >= 0) { return "OP"; } } return null; } }
希望本文所述对大家的JSP程序设计有所帮助。
本文向大家介绍Jsp+Servlet实现文件上传下载 文件上传(一),包括了Jsp+Servlet实现文件上传下载 文件上传(一)的使用技巧和注意事项,需要的朋友参考一下 文件上传和下载功能是Java Web必备技能,很实用。 本文使用的是Apache下的著名的文件上传组件 org.apache.commons.fileupload 实现 下面结合最近看到的一些资料以及自己的尝试,先写第一篇文件上
本文向大家介绍JSP response对象实现文件下载的两种方式,包括了JSP response对象实现文件下载的两种方式的使用技巧和注意事项,需要的朋友参考一下 一.JSP隐含对象response实现文件下载的介绍 (1)在JSP中实现文件下载最简单的方法是定义超链接指向目标资源,用户单击超链接后直接下载资源,但直接暴露资源的URL 也会带来一些负面的影响,例如容易被其它网站盗链,造成本地服务器
本文向大家介绍Servlet实现代理文件下载功能,包括了Servlet实现代理文件下载功能的使用技巧和注意事项,需要的朋友参考一下 用户向代理服务器发送请求,代理服务器从后端服务器上获取文件,并返回给用户 web.xml: servlet: 参考:一个文件下载的Servlet 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
问题内容: 我应该如何实现简单的文件下载servlet? 这个想法是,通过请求,用户可以下载例如。从文件中读取,文件会将文件上传给用户。 我可以获取文件,但是如何实现文件下载? 问题答案: 那要看。如果你可以通过HTTP服务器或Servlet容器公开访问该文件,则只需将其重定向到via即可。 如果不是,则需要手动将其复制到响应输出流: 当然,你需要处理适当的异常。
本文向大家介绍JSP隐含对象response实现文件下载,包括了JSP隐含对象response实现文件下载的使用技巧和注意事项,需要的朋友参考一下 一.简单介绍JSP隐含对象response实现文件下载 (1)在JSP中实现文件下载最简单的方法是定义超链接指向目标资源,用户单击超链接后直接下载资源,但直接暴露资源的URL也会带来一些负面的影响,例如容易被其它网站盗链,造成本地服务器下载负载过重。
本文向大家介绍C#实现HTTP下载文件的方法,包括了C#实现HTTP下载文件的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现HTTP下载文件的方法。分享给大家供大家参考。 主要实现代码如下: 希望本文所述对大家的C#程序设计有所帮助。