国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

Apache如何實(shí)現文件上傳與文件下載

發(fā)布時(shí)間:2021-08-17 12:35 來(lái)源:億速云 閱讀:0 作者:小新 欄目: 服務(wù)器 歡迎投稿:712375056

小編給大家分享一下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í)歡迎投稿傳遞力量。

久久99国内精品自在现线| 日韩在线看片免费人成视频播放| 999精产国品一二三产区区| 成人免费无码成人影院日韩| 四虎影视在线永久免费观看| 性少妇MDMS丰满HDFILM|