小編給大家分享一下Apache如何實(shí)現文件上傳與文件下載,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
web.xml配置如下:
<span ><?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> <display-name>FileUploadAndDownload</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <!-- 上傳配置 --> <servlet> <servlet-name>uploadHandleServlet</servlet-name> <servlet-class>com.zeng.controller.UploadHandleServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>uploadHandleServlet</servlet-name> <url-pattern>/upload/uploadHandleServlet</url-pattern> </servlet-mapping> <servlet> <servlet-name>listFileServlet</servlet-name> <servlet-class>com.zeng.controller.ListFileServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>listFileServlet</servlet-name> <url-pattern>/listFileServlet</url-pattern> </servlet-mapping> <servlet> <servlet-name>downLoadServlet</servlet-name> <servlet-class>com.zeng.controller.DownLoadServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>downLoadServlet</servlet-name> <url-pattern>/download/downLoadServlet</url-pattern> </servlet-mapping> </web-app></span>
2.upload.jsp文件
<span ><%@page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML> <html> <head> <title>文件上傳</title> </head> <body> <!-- ${pageContext.request.contextPath} : 作用是取出部署的應用程序名 缺點(diǎn):操作不便,其他工具無(wú)法正確解釋${pageContext.request.contextPath} 如果Servlet的配置路徑為 /upload/uploadHandleServlet action跳轉路徑為: ${pageContext.request.contextPath}/upload/uploadHandleServlet 上傳文件時(shí),必須 1.enctype="multipart/form-data" 2.method=post --> <form action="${pageContext.request.contextPath}/upload/uploadHandleServlet" enctype="multipart/form-data" method="post"> 上傳用戶(hù):<input type="text" name="username"><br/> 上傳文件1:<input type="file" name="file1"><br/> 上傳文件2:<input type="file" name="file2"><br/> <input type="submit" value="提交"> </form> </body> </html></span>
3.message.jsp
<span ><%@page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML> <html> <head> <title>消息提示</title> </head> <body> ${message} </body> </html></span>
4.UploadHandleServlet.java
<span >package com.zeng.controller; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.util.List; import java.util.UUID; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileUploadBase; import org.apache.commons.fileupload.ProgressListener; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; /** * @ClassName: UploadHandleServlet * @Description: TODO(這里用一句話(huà)描述這個(gè)類(lèi)的作用) */ public class UploadHandleServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //得到上傳文件的保存目錄,將上傳的文件存放于WEB-INF目錄下,不允許外界直接訪(fǎng)問(wèn),保證上傳文件的安全 String savePath = this.getServletContext().getRealPath("/WEB-INF/upload"); //上傳時(shí)生成的臨時(shí)文件保存目錄 String tempPath = this.getServletContext().getRealPath("/WEB-INF/temp"); File tmpFile = new File(tempPath); if (!tmpFile.exists()) { //創(chuàng )建臨時(shí)目錄 tmpFile.mkdir(); } //消息提示 String message = ""; try{ //使用Apache文件上傳組件處理文件上傳步驟: //1、創(chuàng )建一個(gè)DiskFileItemFactory工廠(chǎng) DiskFileItemFactory factory = new DiskFileItemFactory(); //設置工廠(chǎng)的緩沖區的大小,當上傳的文件大小超過(guò)緩沖區的大小時(shí),就會(huì )生成一個(gè)臨時(shí)文件存放到指定的臨時(shí)目錄當中。 factory.setSizeThreshold(1024*100);//設置緩沖區的大小為100KB,如果不指定,那么緩沖區的大小默認是10KB //設置上傳時(shí)生成的臨時(shí)文件的保存目錄 factory.setRepository(tmpFile); //2、創(chuàng )建一個(gè)文件上傳解析器 ServletFileUpload upload = new ServletFileUpload(factory); //監聽(tīng)文件上傳進(jìn)度 upload.setProgressListener(new ProgressListener(){ public void update(long pBytesRead, long pContentLength, int arg2) { System.out.println("文件大小為:" + pContentLength + ",當前已處理:" + pBytesRead + ",arg2: " + arg2); /** * 文件大小為:14608,當前已處理:4096 文件大小為:14608,當前已處理:7367 文件大小為:14608,當前已處理:11419 文件大小為:14608,當前已處理:14608 */ } }); //解決上傳文件名的中文亂碼 upload.setHeaderEncoding("UTF-8"); //3、判斷提交上來(lái)的數據是否是上傳表單的數據 if(!ServletFileUpload.isMultipartContent(request)){ //按照傳統方式獲取數據 return; } //設置上傳單個(gè)文件的大小的最大值,目前是設置為1024*1024*20字節,也就是20MB upload.setFileSizeMax(1024*1024*20); //設置上傳文件總量的最大值,最大值=同時(shí)上傳的多個(gè)文件的大小的最大值的和,目前設置為100MB upload.setSizeMax(1024*1024*100); //4、使用ServletFileUpload解析器解析上傳數據,解析結果返回的是一個(gè)List<FileItem>集合,每一個(gè)FileItem對應一個(gè)Form表單的輸入項 List<FileItem> list = upload.parseRequest(request); for(FileItem item : list){ //如果fileitem中封裝的是普通輸入項的數據 if(item.isFormField()){ String name = item.getFieldName(); //解決普通輸入項的數據的中文亂碼問(wèn)題 String value = item.getString("UTF-8"); System.out.println(name + "=" + value); }else{//如果fileitem中封裝的是上傳文件 //得到上傳的文件名稱(chēng), String filename = item.getName(); System.out.println(filename); if(filename==null || filename.trim().equals("")){ continue; } //注意:不同的瀏覽器提交的文件名是不一樣的,有些瀏覽器提交上來(lái)的文件名是帶有路徑的,如: c:\a\b\1.txt,而有些只是單純的文件名,如:1.txt //處理獲取到的上傳文件的文件名的路徑部分,只保留文件名部分 filename = filename.substring(filename.lastIndexOf("\\")+1); //得到上傳文件的擴展名 String fileExtName = filename.substring(filename.lastIndexOf(".")+1); //如果需要限制上傳的文件類(lèi)型,那么可以通過(guò)文件的擴展名來(lái)判斷上傳的文件類(lèi)型是否合法 System.out.println("上傳的文件的擴展名是:"+fileExtName); //獲取item中的上傳文件的輸入流 InputStream in = item.getInputStream(); //得到文件保存的名稱(chēng) String saveFilename = makeFileName(filename); //文件名:d507ef2e-aca9-4908-a8b9-c1d1c6a2f4d9_日語(yǔ)二級語(yǔ)法大全(推薦).doc //System.out.println("saveFilename: " + saveFilename); //得到文件的保存目錄 String realSavePath = makePath(saveFilename, savePath); //創(chuàng )建一個(gè)文件輸出流 FileOutputStream out = new FileOutputStream(realSavePath + "\\" + saveFilename); //創(chuàng )建一個(gè)緩沖區 byte buffer[] = new byte[1024]; //判斷輸入流中的數據是否已經(jīng)讀完的標識 int len = 0; //循環(huán)將輸入流讀入到緩沖區當中,(len=in.read(buffer))>0就表示in里面還有數據 while((len=in.read(buffer))>0){ //使用FileOutputStream輸出流將緩沖區的數據寫(xiě)入到指定的目錄(savePath + "\\" + filename)當中 out.write(buffer, 0, len); } //關(guān)閉輸入流 in.close(); //關(guān)閉輸出流 out.close(); //刪除處理文件上傳時(shí)生成的臨時(shí)文件 //item.delete(); message = "文件上傳成功!"; } } }catch (FileUploadBase.FileSizeLimitExceededException e) { e.printStackTrace(); request.setAttribute("message", "單個(gè)文件超出最大值?。?!"); request.getRequestDispatcher("../message.jsp").forward(request, response); return; }catch (FileUploadBase.SizeLimitExceededException e) { e.printStackTrace(); request.setAttribute("message", "上傳文件的總的大小超出限制的最大值?。?!"); request.getRequestDispatcher("../message.jsp").forward(request, response); return; }catch (Exception e) { message= "文件上傳失??!"; e.printStackTrace(); } request.setAttribute("message",message); //訪(fǎng)問(wèn)路徑 /FileUploadAndDownload/upload/upload.jsp //跳轉路徑 /FileUploadAndDownload/upload/listFileServlet //轉發(fā)路徑 /FileUploadAndDownload/message.jsp //當前路徑是在/FileUploadAndDownload/upload/下,要跳到/FileUploadAndDownload/下,必須../message.jsp //-----如果 message.jsp是在/FileUploadAndDownload/upload/下,則直接使用message.jsp request.getRequestDispatcher("../message.jsp").forward(request, response); } /** * @Method: makeFileName * @Description: 生成上傳文件的文件名,文件名以:uuid+"_"+文件的原始名稱(chēng) * @param filename 文件的原始名稱(chēng) * @return uuid+"_"+文件的原始名稱(chēng) */ private String makeFileName(String filename){ //2.jpg //為防止文件覆蓋的現象發(fā)生,要為上傳文件產(chǎn)生一個(gè)唯一的文件名 return UUID.randomUUID().toString() + "_" + filename; } /** * 為防止一個(gè)目錄下面出現太多文件,要使用hash算法打散存儲 * @Method: makePath * @param filename 文件名,要根據文件名生成存儲目錄 * @param savePath 文件存儲路徑 * @return 新的存儲目錄 */ private String makePath(String filename,String savePath){ //得到文件名的hashCode的值,得到的就是filename這個(gè)字符串對象在內存中的地址 int hashcode = filename.hashCode(); int dir1 = hashcode&0xf; //0--15 int dir2 = (hashcode&0xf0)>>4; //0-15 //構造新的保存目錄 String dir = savePath + "\\" + dir1 + "\\" + dir2; //upload\2\3 upload\3\5 //hashcode: -1390239557 dir1: 11 dir: 11 (以d507ef2e-aca9-4908-a8b9-c1d1c6a2f4d9_日語(yǔ)二級語(yǔ)法大全(推薦).doc為例子) System.out.println("上傳前:hashcode: "+ hashcode + " dir1: " +dir1 + " dir: " + dir2); //File既可以代表文件也可以代表目錄 File file = new File(dir); //如果目錄不存在 if(!file.exists()){ //創(chuàng )建目錄 file.mkdirs(); } return dir; } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } } // ----------------------------------------------------------簡(jiǎn)單版本,不處理上傳空間和上傳的文件名 // //import java.io.File; //import java.io.FileOutputStream; //import java.io.IOException; //import java.io.InputStream; //import java.util.List; //import javax.servlet.ServletException; //import javax.servlet.http.HttpServlet; //import javax.servlet.http.HttpServletRequest; //import javax.servlet.http.HttpServletResponse; //import org.apache.commons.fileupload.FileItem; //import org.apache.commons.fileupload.disk.DiskFileItemFactory; //import org.apache.commons.fileupload.servlet.ServletFileUpload; // //public class UploadHandleServlet extends HttpServlet { // // public void doGet(HttpServletRequest request, HttpServletResponse response) // throws ServletException, IOException { // //得到上傳文件的保存目錄,將上傳的文件存放于WEB-INF目錄下,不允許外界直接訪(fǎng)問(wèn),保證上傳文件的安全 // String savePath = this.getServletContext().getRealPath("/WEB-INF/upload"); // File file = new File(savePath); // //判斷上傳文件的保存目錄是否存在 // if (!file.exists() && !file.isDirectory()) { // System.out.println(savePath+"目錄不存在,需要創(chuàng )建"); // //創(chuàng )建目錄 // file.mkdir(); // } // //消息提示 // String message = ""; // try{ // //使用Apache文件上傳組件處理文件上傳步驟: // //1、創(chuàng )建一個(gè)DiskFileItemFactory工廠(chǎng) // DiskFileItemFactory factory = new DiskFileItemFactory(); // //2、創(chuàng )建一個(gè)文件上傳解析器 // ServletFileUpload upload = new ServletFileUpload(factory); // //解決上傳文件名的中文亂碼 // upload.setHeaderEncoding("UTF-8"); // //3、判斷提交上來(lái)的數據是否是上傳表單的數據 // if(!ServletFileUpload.isMultipartContent(request)){ // //按照傳統方式獲取數據 // return; // } // //4、使用ServletFileUpload解析器解析上傳數據,解析結果返回的是一個(gè)List<FileItem>集合,每一個(gè)FileItem對應一個(gè)Form表單的輸入項 // List<FileItem> list = upload.parseRequest(request); // for(FileItem item : list){ // //如果fileitem中封裝的是普通輸入項的數據 // if(item.isFormField()){ // String name = item.getFieldName(); // //解決普通輸入項的數據的中文亂碼問(wèn)題 // String value = item.getString("UTF-8"); // //value = new String(value.getBytes("iso8859-1"),"UTF-8"); // System.out.println(name + "=" + value); // }else{//如果fileitem中封裝的是上傳文件 // //得到上傳的文件名稱(chēng), // String filename = item.getName(); // System.out.println(filename); // if(filename==null || filename.trim().equals("")){ // continue; // } // //注意:不同的瀏覽器提交的文件名是不一樣的,有些瀏覽器提交上來(lái)的文件名是帶有路徑的,如: c:\a\b\1.txt,而有些只是單純的文件名,如:1.txt // //處理獲取到的上傳文件的文件名的路徑部分,只保留文件名部分 // filename = filename.substring(filename.lastIndexOf("\\")+1); // //獲取item中的上傳文件的輸入流 // InputStream in = item.getInputStream(); // //創(chuàng )建一個(gè)文件輸出流 // FileOutputStream out = new FileOutputStream(savePath + "\\" + filename); // //創(chuàng )建一個(gè)緩沖區 // byte buffer[] = new byte[1024]; // //判斷輸入流中的數據是否已經(jīng)讀完的標識 // int len = 0; // //循環(huán)將輸入流讀入到緩沖區當中,(len=in.read(buffer))>0就表示in里面還有數據 // while((len=in.read(buffer))>0){ // //使用FileOutputStream輸出流將緩沖區的數據寫(xiě)入到指定的目錄(savePath + "\\" + filename)當中 // out.write(buffer, 0, len); // } // //關(guān)閉輸入流 // in.close(); // //關(guān)閉輸出流 // out.close(); // //刪除處理文件上傳時(shí)生成的臨時(shí)文件 // item.delete(); // message = "文件上傳成功!"; // } // } // }catch (Exception e) { // message= "文件上傳失??!"; // e.printStackTrace(); // // } // request.setAttribute("message",message); // request.getRequestDispatcher("/message.jsp").forward(request, response); // } // // public void doPost(HttpServletRequest request, HttpServletResponse response) // throws ServletException, IOException { // // doGet(request, response); // } /
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站