• servlet上传下载(任何格式的都可以)


    jar不能低于此版本,JDK1.6以上,否则户报错

    1. <dependency>
    2. <groupId>commons-fileupload</groupId>
    3. <artifactId>commons-fileupload</artifactId>
    4. <version>1.3.1</version>
    5. </dependency>
    一、上传文件
    1. package com.odj.common.upload;
    2. import java.io.File;
    3. import java.io.FileOutputStream;
    4. import java.io.IOException;
    5. import java.io.InputStream;
    6. import java.util.List;
    7. import javax.servlet.ServletException;
    8. import javax.servlet.http.HttpServlet;
    9. import javax.servlet.http.HttpServletRequest;
    10. import javax.servlet.http.HttpServletResponse;
    11. import org.apache.commons.fileupload.FileItem;
    12. import org.apache.commons.fileupload.FileUploadBase;
    13. import org.apache.commons.fileupload.ProgressListener;
    14. import org.apache.commons.fileupload.disk.DiskFileItemFactory;
    15. import org.apache.commons.fileupload.servlet.ServletFileUpload;
    16. public class UploadHandleServlet extends HttpServlet {
    17. /**
    18. *
    19. */
    20. private static final long serialVersionUID = 1L;
    21. public void doGet(HttpServletRequest request, HttpServletResponse response)
    22. throws ServletException, IOException {
    23. doPost(request, response);
    24. }
    25. /**
    26. * @Method: makeFileName *
    27. * @Description: 生成上传文件的文件名,文件名以:uuid+"_"+文件的原始名称
    28. * @param filename 文件的原始名称 *
    29. * @return uuid+"_"+文件的原始名称
    30. */
    31. private String makeFileName(String filename) {
    32. // 2.jpg
    33. // 为防止文件覆盖的现象发生,要为上传文件产生一个唯一的文件名
    34. //return UUID.randomUUID().toString() + "_" + filename;
    35. int i = 1;
    36. String s = i + "_" + filename;
    37. i++;
    38. return s;
    39. }
    40. /**
    41. * 为防止一个目录下面出现太多文件,要使用hash算法打散存储
    42. * @Method: makePath
    43. * @param filename 文件名,要根据文件名生成存储目录
    44. * @param savePath 文件存储路径
    45. * @return 新的存储目录
    46. */
    47. private String makePath(String filename, String savePath) {
    48. // 得到文件名的hashCode的值,得到的就是filename这个字符串对象在内存中的地址
    49. int hashcode = filename.hashCode();
    50. int dir1 = hashcode & 0xf; // 0--15
    51. int dir2 = (hashcode & 0xf0) >> 4; // 0-15
    52. // 构造新的保存目录
    53. //String dir = savePath + "\" + dir1 + "\" + dir2;
    54. String dir = savePath;
    55. // upload23 upload35
    56. // File既可以代表文件也可以代表目录
    57. File file = new File(dir);
    58. // 如果目录不存在
    59. if (!file.exists()) {
    60. // 创建目录
    61. file.mkdirs();
    62. }
    63. return dir;
    64. }
    65. public void doPost(HttpServletRequest request, HttpServletResponse response)
    66. throws ServletException, IOException {
    67. // 得到上传文件的保存目录,将上传的文件存放于WEB-INF目录下,不允许外界直接访问,保证上传文件的安全
    68. String savePath = this.getServletContext().getRealPath(
    69. "/WEB-INF/upload");
    70. // 上传时生成的临时文件保存目录
    71. String tempPath = this.getServletContext().getRealPath("/WEB-INF/temp");
    72. File tmpFile = new File(tempPath);
    73. if (!tmpFile.exists()) {
    74.     // 创建临时目录
    75.     tmpFile.mkdir();
    76. }
    77. // 消息提示
    78. String message = "";
    79. try {
    80. // 使用Apache文件上传组件处理文件上传步骤:
    81. // 1、创建一个DiskFileItemFactory工厂
    82. DiskFileItemFactory factory = new DiskFileItemFactory();
    83. // 设置工厂的缓冲区的大小,当上传的文件大小超过缓冲区的大小时,就会生成一个临时文件存放到指定的临时目录当中。
    84. factory.setSizeThreshold(1024 * 100);
    85. // 设置缓冲区的大小为100KB,如果不指定,那么缓冲区的大小默认是10KB
    86. // 设置上传时生成的临时文件的保存目录
    87. factory.setRepository(tmpFile);
    88. // 2、创建一个文件上传解析器
    89. ServletFileUpload upload = new ServletFileUpload(factory);
    90. // 监听文件上传进度
    91. upload.setProgressListener(new ProgressListener() {
    92. public void update(long pBytesRead, long pContentLength,int arg2) {
    93. System.out.println("文件大小为:" + pContentLength + ",当前已处理:" + pBytesRead);
    94. /**
    95. * 文件大小为:14608,当前已处理:4096 文件大小为:14608,当前已处理:7367
    96. * 文件大小为:14608,当前已处理:11419 文件大小为:14608,当前已处理:14608
    97. */
    98. }
    99. });
    100. // 解决上传文件名的中文乱码
    101. upload.setHeaderEncoding("GBK");
    102. // 3、判断提交上来的数据是否是上传表单的数据
    103. if (!ServletFileUpload.isMultipartContent(request)) {
    104. // 按照传统方式获取数据
    105. return;
    106. }
    107. // 设置上传单个文件的大小的最大值,目前是设置为1024*1024字节,也就是100MB+++++++++++++++++++++++++++++++++++++
    108. upload.setFileSizeMax(1024 * 1024 * 100);
    109. // 设置上传文件总量的最大值,最大值=同时上传的多个文件的大小的最大值的和,目前设置为100MB
    110. upload.setSizeMax(1024 * 1024 *100);
    111. // 4、使用ServletFileUpload解析器解析上传数据,解析结果返回的是一个List<FileItem>集合,
    112. // 每一个FileItem对应一个Form表单的输入项
    113. List<FileItem> list = upload.parseRequest(request);
    114. for (FileItem item : list) {
    115. // 如果fileitem中封装的是普通输入项的数据
    116. if (item.isFormField()) {
    117. String name = item.getFieldName();
    118. // 解决普通输入项的数据的中文乱码问题
    119. String value = item.getString("GBK");
    120. // value = new String(value.getBytes("iso8859-1"),"UTF-8");
    121. System.out.println(name + "=" + value);
    122. } else {
    123. // 如果fileitem中封装的是上传文件
    124. // 得到上传的文件名称,
    125. String filename = item.getName();
    126. System.out.println(filename);
    127. if (filename == null || filename.trim().equals("")) {
    128. continue;
    129. }
    130. // 注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,
    131. // 如: c:a1.txt,而有些只是单纯的文件名,如:1.txt
    132. // 处理获取到的上传文件的文件名的路径部分,只保留文件名部分
    133. filename = filename.substring(filename.lastIndexOf("\") + 1);
    134. // 得到上传文件的扩展名
    135. String fileExtName = filename.substring(filename.lastIndexOf(".") + 1);
    136. // 如果需要限制上传的文件类型,那么可以通过文件的扩展名来判断上传的文件类型是否合法
    137. System.out.println("上传的文件的扩展名是:" + fileExtName);
    138. // 获取item中的上传文件的输入流
    139. InputStream in = item.getInputStream();
    140. // 得到文件保存的名称
    141. String saveFilename = makeFileName(filename);
    142. // 得到文件的保存目录
    143. String realSavePath = makePath(saveFilename, savePath);
    144. // 创建一个文件输出流(这里在linux不能用‘’只能用‘/’
    145. FileOutputStream out = new FileOutputStream(realSavePath + "\" + saveFilename);
    146. // 创建一个缓冲区
    147. byte buffer[] = new byte[1024];
    148. // 判断输入流中的数据是否已经读完的标识
    149. int len = 0;
    150. // 循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据
    151. while ((len = in.read(buffer)) > 0) {
    152. // 使用FileOutputStream输出流将缓冲区的数据写入到指定的目录(savePath + "\"
    153. // + filename)当中
    154. out.write(buffer, 0, len);
    155. }
    156. // 关闭输入流
    157. in.close();
    158. // 关闭输出流
    159. out.close();
    160. // 删除处理文件上传时生成的临时文件
    161. // item.delete();
    162. message = "文件上传成功!";
    163. }
    164. }
    165. } catch (FileUploadBase.FileSizeLimitExceededException e) {
    166. e.printStackTrace();
    167. request.setAttribute("message", "单个文件超出最大值100M!!!");
    168. request.getRequestDispatcher("/upload.jsp").forward(request,
    169. response);
    170. return;
    171. } catch (FileUploadBase.SizeLimitExceededException e) {
    172. e.printStackTrace();
    173. request.setAttribute("message", "上传文件的总的大小超出限制的最大值100M!!!");
    174. request.getRequestDispatcher("/upload.jsp").forward(request,
    175. response);
    176. return;
    177. } catch (Exception e) {
    178. message = "文件上传失败!";
    179. e.printStackTrace();
    180. }
    181. request.setAttribute("message", message);
    182. request.getRequestDispatcher("/upload.jsp").forward(request, response);
    183. }
    184. }
    jsp、
    1. <%@ page contentType="text/html; charset=GBK"%>
    2. <%
    3. String path = request.getContextPath();
    4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    5. %>
    6. <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    7. <%@ page isELIgnored="false"%>
    8. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    9. <html>
    10. <head>
    11. <base href="<%=basePath%>">
    12. <title>My JSP 'upload.jsp' starting page</title>
    13. <metahttp-equiv="pragma"content="no-cache">
    14. <metahttp-equiv="cache-control"content="no-cache">
    15. <metahttp-equiv="expires"content="0">
    16. <metahttp-equiv="keywords"content="keyword1,keyword2,keyword3">
    17. <metahttp-equiv="description"content="This is my page">
    18. <!--
    19. <link rel="stylesheet" type="text/css" href="styles.css">
    20. -->
    21. <SCRIPTtype="text/javascript"src="${pageContext.request.contextPath }/bg/common/js/jquery-1.8.1.min.js"></SCRIPT>
    22. </head>
    23. <scripttype="text/javascript">
    24. $(function(){
    25. })
    26. </script>
    27. <body>
    28. <divalign="center"style="padding-top:100px;">
    29. <div><spanstyle="color: red;">${message }</span></div>
    30. <formaction="${pageContext.request.contextPath }/servlet/UploadHandleServlet"enctype="multipart/form-data"method="post">
    31. 上传用户:<inputtype="text"name="username"><br/>
    32. 上传文件1:<inputtype="file"name="file1"><br/>
    33. 上传文件2:<inputtype="file"name="file2"><br/>
    34. <inputtype="submit"value="提交">
    35. </form>
    36. <div>
    37. <ahref="${pageContext.request.contextPath }/servlet/ListFileServlet">进入下载页</a>
    38. </div>
    39. </div>
    40. <scripttype="text/javascript">
    41. $(function(){
    42. //window.location.href="${pageContext.request.contextPath }/404.html";
    43. })
    44. </script>
    45. </body>
    46. </html>
    二、显示下载的内容
    1. package com.odj.common.upload;
    2. import java.io.File;
    3. import java.io.IOException;
    4. import java.util.HashMap;
    5. import java.util.Map;
    6. import javax.servlet.ServletException;
    7. import javax.servlet.http.HttpServlet;
    8. import javax.servlet.http.HttpServletRequest;
    9. import javax.servlet.http.HttpServletResponse;
    10. /**
    11. * 列出Web系统中所有下载文件
    12. * @author tanyicheng
    13. * 2016年9月28日-下午8:59:17
    14. */
    15. public class ListFileServlet extends HttpServlet {
    16. public void doGet(HttpServletRequest request, HttpServletResponse response)
    17. throws ServletException, IOException {
    18. doPost(request, response);
    19. }
    20. /**
    21. * 递归遍历指定目录下的所有文件
    22. * @author tanyicheng 2016年9月28日-下午8:59:36
    23. * @param file 即代表一个文件,也代表一个文件目录
    24. * @param map map存储文件名的Map集合
    25. */
    26. public void listfile(File file, Map<String, String> map) {
    27. // 如果file代表的不是一个文件,而是一个目录
    28. if (!file.isFile()) {
    29. // 列出该目录下的所有文件和目录
    30. File files[] = file.listFiles();
    31. // 遍历files[]数组
    32. if(files != null ){
    33. for (File f : files) {
    34. // 递归
    35. listfile(f, map);
    36. }
    37. }else{
    38. map.put("name", "暂无文件");
    39. return;
    40. }
    41. } else {
    42. /**
    43. * 处理文件名,上传后的文件是以uuid_文件名的形式去重新命名的,去除文件名的uuid_部分
    44. * file.getName().indexOf("_")检索字符串中第一次出现"_"字符的位置,
    45. * 如果文件名类似于:9349249849-88343-8344_阿_凡_达.avi那么
    46. * file.getName().substring(file.getName().indexOf("_")+1) 处理之后就可以得到阿_凡_达.avi部分
    47. * */
    48. String realName = file.getName().substring(file.getName().indexOf("_") + 1);
    49. // file.getName()得到的是文件的原始名称,这个名称是唯一的,因此可以作为key,realName是处理过后的名称,有可能会重复
    50. map.put(file.getName(), realName);
    51. }
    52. }
    53. /**
    54. * 列出Web系统中所有下载文件
    55. */
    56. public void doPost(HttpServletRequest request, HttpServletResponse response)
    57. throws ServletException, IOException {
    58. // 获取上传文件的目录
    59. String uploadFilePath = this.getServletContext().getRealPath("/WEB-INF/upload");
    60. // 存储要下载的文件名
    61. Map<String, String> fileNameMap = new HashMap<String, String>();
    62. // 递归遍历filepath目录下的所有文件和目录,将文件的文件名存储到map集合中
    63. listfile(new File(uploadFilePath), fileNameMap);
    64. // File既可以代表一个文件也可以代表一个目录
    65. // 将Map集合发送到listfile.jsp页面进行显示
    66. if(fileNameMap == null){
    67. fileNameMap.put("fileNameMap", "暂无文件");
    68. }else{
    69. request.setAttribute("fileNameMap", fileNameMap);
    70. }
    71. request.getRequestDispatcher("/listfile.jsp").forward(request, response);
    72. }
    73. }
    jsp、
    1. <%@ page language="java" contentType="text/html; charset=UTF-8"
    2. pageEncoding="UTF-8"%>
    3. <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
    4. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    5. <html>
    6. <head>
    7. <metahttp-equiv="Content-Type"content="text/html; charset=UTF-8">
    8. <title>Insert title here</title>
    9. </head>
    10. <body>
    11. <!-- 遍历Map集合 -->
    12. <c:forEachvar="me"items="${fileNameMap}">
    13. <c:urlvalue="/servlet/DownLoadServlet"var="downurl">
    14. <c:paramname="filename"value="${me.key}"></c:param>
    15. </c:url>${me.value}<ahref="${downurl}">下载</a>
    16. <br/>
    17. </c:forEach>
    18. </body>
    19. </html>
    三、下载文件
    1. package com.odj.common.upload;
    2. import java.io.File;
    3. import java.io.FileInputStream;
    4. import java.io.IOException;
    5. import java.io.OutputStream;
    6. import java.net.URLEncoder;
    7. import javax.servlet.ServletException;
    8. import javax.servlet.http.HttpServlet;
    9. import javax.servlet.http.HttpServletRequest;
    10. import javax.servlet.http.HttpServletResponse;
    11. public class DownLoadServlet extends HttpServlet {
    12. public void doGet(HttpServletRequest request, HttpServletResponse response)
    13. throws ServletException, IOException {
    14. // 得到要下载的文件名
    15. String fileName = request.getParameter("filename");
    16. // 23239283-92489-阿凡达.
    17. fileName = new String(fileName.getBytes("iso8859-1"),"UTF-8");
    18. // 上传的文件都是保存在/WEB-INF/upload目录下的子目录当中
    19. String fileSaveRootPath = this.getServletContext().getRealPath("/WEB-INF/upload");
    20. // 通过文件名找出文件的所在目录(这里暂没有多级目录)
    21. //String path = findFileSavePathByFileName(fileName, fileSaveRootPath);
    22. // 得到要下载的文件(如果使用多级目录需要将fileSaveRootPath换为path************************************************)
    23. File file = new File(fileSaveRootPath + "\" + fileName);
    24. // 如果文件不存在
    25. if (!file.exists()) {
    26. request.setAttribute("message", "您要下载的资源已被删除!!");
    27. request.getRequestDispatcher("/upload.jsp").forward(request,response);
    28. return;
    29. }
    30. // 处理文件名
    31. String realname = fileName.substring(fileName.indexOf("_") + 1);
    32. // 设置响应头,控制浏览器下载该文件
    33. response.setHeader("content-disposition", "attachment;filename="+ URLEncoder.encode(realname, "GBK"));
    34. // 读取要下载的文件,保存到文件输入流
    35. FileInputStream in = new FileInputStream(fileSaveRootPath + "\" + fileName);
    36. // 创建输出流
    37. OutputStream out = response.getOutputStream();
    38. // 创建缓冲区
    39. byte buffer[] = new byte[1024];
    40. int len = 0;
    41. // 循环将输入流中的内容读取到缓冲区当中
    42. while ((len = in.read(buffer)) > 0) {
    43. // 输出缓冲区的内容到浏览器,实现文件下载
    44. out.write(buffer, 0, len);
    45. }
    46. // 关闭文件输入流
    47. in.close();
    48. // 关闭输出流
    49. out.close();
    50. }
    51. /***
    52. * @Method: findFileSavePathByFileName
    53. * @Description:通过文件名和存储上传文件根目录找出要下载的文件的所在路径
    54. * @param filename 要下载的文件名
    55. * @param saveRootPath 上传文件保存的根目录,也就是/WEB-INF/upload目录
    56. * @return 要下载的文件的存储目录
    57. */
    58. public String findFileSavePathByFileName(String filename,String saveRootPath) {
    59. int hashcode = filename.hashCode();
    60. int dir1 = hashcode & 0xf;
    61. // 0--15
    62. int dir2 = (hashcode & 0xf0) >> 4;
    63. // 0-15
    64. String dir = saveRootPath + "\" + dir1 + "\" + dir2;
    65. // upload23 upload35
    66. File file = new File(dir);
    67. if (!file.exists()) {
    68. // 创建目录
    69. file.mkdirs();
    70. }
    71. return dir;
    72. }
    73. public void doPost(HttpServletRequest request, HttpServletResponse response)
    74. throws ServletException, IOException {
    75. doGet(request, response);
    76. }
    77. }
    最后、web.xml
    1. <!-- servlet上传、下载文件 start -->
    2. <servlet>
    3. <servlet-name>UploadHandleServlet</servlet-name>
    4. <servlet-class>com.odj.common.upload.UploadHandleServlet</servlet-class>
    5. </servlet>
    6. <servlet-mapping>
    7. <servlet-name>UploadHandleServlet</servlet-name>
    8. <url-pattern>/servlet/UploadHandleServlet</url-pattern>
    9. </servlet-mapping>
    10. <!-- 显示可以下载的内容 -->
    11. <servlet>
    12. <servlet-name>ListFileServlet</servlet-name>
    13. <servlet-class>com.odj.common.upload.ListFileServlet</servlet-class>
    14. </servlet>
    15. <servlet-mapping>
    16. <servlet-name>ListFileServlet</servlet-name>
    17. <url-pattern>/servlet/ListFileServlet</url-pattern>
    18. </servlet-mapping>
    19. <!-- 文件下载 -->
    20. <servlet>
    21. <servlet-name>DownLoadServlet</servlet-name>
    22. <servlet-class>com.odj.common.upload.DownLoadServlet</servlet-class>
    23. </servlet>
    24. <servlet-mapping>
    25. <servlet-name>DownLoadServlet</servlet-name>
    26. <url-pattern>/servlet/DownLoadServlet</url-pattern>
    27. </servlet-mapping>
    28. <!-- 文件上传下载 end -->
     
     
     





  • 相关阅读:
    tensorflow2.0——动量,动态学习率,Dropout
    tensorflow2.0——过拟合优化regularization(简化参数结构,添加参数代价变量)
    tensorflow2.0——自定义全连接层实现并保存
    关于生成器的问题
    端午节大礼包(投票系统)
    写一个函数完成三次登陆功能,再写一个函数完成注册功能
    例题练习
    文件操作
    解决列表中增加字典覆盖之前相同key的字典
    字符串操作,列表,元组,字典操作
  • 原文地址:https://www.cnblogs.com/-odj/p/6014756.html
Copyright © 2020-2023  润新知