溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在java項(xiàng)目中實(shí)現(xiàn)一個(gè)文件上傳功能

發(fā)布時(shí)間:2020-12-14 14:33:45 來源:億速云 閱讀:379 作者:Leah 欄目:開發(fā)技術(shù)

怎么在java項(xiàng)目中實(shí)現(xiàn)一個(gè)文件上傳功能?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

一、文件上傳準(zhǔn)備工作

對于文件上傳,瀏覽器在上傳的過程中將文件以流的形式提交到服務(wù)器。
可以選擇apache的commons-fileupload包作為文件上傳組件,
commons-fileupload包依賴于commons-io包。
可以在Maven導(dǎo)入該commons-fileupload包,Maven會(huì)幫我們導(dǎo)入依賴的jar包c(diǎn)ommons-io。

<dependency>
 <groupId>commons-fileupload</groupId>
 <artifactId>commons-fileupload</artifactId>
 <version>1.3.3</version>
</dependency>

二、文件上傳的主要步驟

  • 創(chuàng)建diskFileItemFactory對象,處理文件上傳路徑或者大小限制

  • 通過diskFileItemFactory對象作為ServletFileUpload類的參數(shù),創(chuàng)建ServletFileUpload對象

  • 處理上傳的文件

三、代碼實(shí)現(xiàn)

在文件上傳時(shí),表單一定要加enctype=“multipart/form-data” 。只有使用enctype=“multipart/form-data”,表單才會(huì)把文件的內(nèi)容編碼到HTML請求中。
默認(rèn)enctype=“application/x-www-form-urlencoded”,表單的內(nèi)容會(huì)按URL規(guī)則編碼。
而enctype="multipart/form-data"不對字符編碼。在使用包含文件上傳控件的表單時(shí),必須使用該值。

method也一定要使用post請求。

<form action="/file.do" enctype="multipart/form-data" method="post">
 <p>上傳用戶:<input type="text" name="username"></p>
 <p><input type="file" name="file1"></p>
 <p><input type="file" name="file2"></p>
 <p><input type="submit">|<input type="reset"></p>
</form>
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  //判斷上傳的是普通表單還是帶文件的表單
  if (!ServletFileUpload.isMultipartContent(req)) {
   return;
  }
  //創(chuàng)建上傳文件保存的地址,一般創(chuàng)建在WEB-INF目錄下,用戶無法直接訪問該目錄下的文件
  String uploadPath = this.getServletContext().getRealPath("/WEB-INF/upload");
  File uploadFile = new File(uploadPath);
  //如果文件夾不存在,則創(chuàng)建一個(gè)
  if (!uploadFile.exists()) {
   uploadFile.mkdir();
  }

  //創(chuàng)建上傳大文件的臨時(shí)地址,一般幾天后自動(dòng)刪除,用戶可以手動(dòng)刪除或者轉(zhuǎn)為永久文件
  // 一般創(chuàng)建在WEB-INF目錄下,用戶無法直接訪問該目錄下的文件
  String tempPath = this.getServletContext().getRealPath("/WEB-INF/temp");
  File tempFile = new File(tempPath);
  //如果文件夾不存在,則創(chuàng)建一個(gè)
  if (!tempFile.exists()) {
   tempFile.mkdir();
  }

  //1.創(chuàng)建diskFileItemFactory對象,處理文件上傳路徑或者大小限制
  DiskFileItemFactory factory = getDiskFileItemFactory(tempFile);

  //2.獲取ServletFileUpload
  ServletFileUpload upload = getServletFileUpload(factory);

  //3.處理上傳的文件
  try {
   String msg = uploadParseRequest(upload, req, uploadPath);
   //轉(zhuǎn)發(fā)
   req.setAttribute("msg",msg);
   req.getRequestDispatcher("info.jsp").forward(req, resp);
  } catch (FileUploadException e) {
   e.printStackTrace();
  }
 }


 public DiskFileItemFactory getDiskFileItemFactory(File file) {
  DiskFileItemFactory factory = new DiskFileItemFactory();
  //創(chuàng)建一個(gè)緩存區(qū),當(dāng)上傳文件大于設(shè)置的緩存區(qū)時(shí),將該文件放到臨時(shí)目錄
  factory.setSizeThreshold(1024 * 1024);//緩存區(qū)大小為1M
  factory.setRepository(file);//臨時(shí)目錄
  return factory;
 }

 public ServletFileUpload getServletFileUpload(DiskFileItemFactory factory) {
  ServletFileUpload upload = new ServletFileUpload(factory);
  //監(jiān)聽文件上傳進(jìn)度
  upload.setProgressListener(new ProgressListener() {
   @Override
   public void update(long uploaded, long totalSize, int i) {
    System.out.println("已上傳:"+(uploaded*100)/totalSize+"%");
   }
  });
  upload.setHeaderEncoding("UTF-8");//亂碼處理
  upload.setFileSizeMax(1024 * 1024 * 10);//設(shè)置單個(gè)文件的最大值10M
  upload.setSizeMax(1024 * 1024 * 100);//設(shè)置總共能上傳文件的最大值100M
  return upload;
 }

 public String uploadParseRequest(ServletFileUpload upload, HttpServletRequest req, String uploadPath) throws FileUploadException, IOException {
  String msg = "";
  //把前端請求解析,封裝成一個(gè)List對象
  List<FileItem> fileItems = upload.parseRequest(req);
  for (FileItem fileItem : fileItems) {
   if (fileItem.isFormField()) {//判斷上傳的文件是普通的表單還是帶文件的表單
    String name = fileItem.getName();//前端表單控件的name:username
    String value = fileItem.getString("UTF-8");//亂碼處理
    System.out.println(name + ":" + value);
   } else {//判斷為上傳的文件
    //==================處理文件=====================
    String uploadFileName = fileItem.getName();//前端表單控件的name
    System.out.println("上傳的文件名:" + uploadFileName);
    if (uploadFileName.trim().equals("") || uploadFileName == null) {//可能存在不合法的情況
     continue;
    }
    String fileName = uploadFileName.substring(uploadFileName.lastIndexOf("/") + 1);//文件名
    String fileExtName = uploadFileName.substring(uploadFileName.lastIndexOf(".") + 1);//文件后綴名
    System.out.println("文件名:" + fileName + "--文件后綴:" + fileExtName);
    //==================存放地址==================
    String uuidPath = UUID.randomUUID().toString();
    //文件存儲的真實(shí)路徑
    String realPath = uploadPath + "/" + uuidPath;
    System.out.println("文件上傳到的位置:"+realPath);
    //給每個(gè)文件創(chuàng)建一個(gè)文件夾
    File realPathFile = new File(realPath);
    if (!realPathFile.exists()) {//如果文件夾不存在,則創(chuàng)建一個(gè)
     realPathFile.mkdir();
    }
    //==================文件傳輸==================
    //獲得文件上傳的流
    InputStream inputStream = fileItem.getInputStream();
    //創(chuàng)建一個(gè)文件輸出流
    FileOutputStream fileOutputStream = new FileOutputStream(realPath + "/" + fileName);
    //創(chuàng)建一個(gè)緩沖區(qū)
    byte[] buffer = new byte[1024 * 1024];
    //判斷讀取是否完畢
    int len = 0;
    while ((len = inputStream.read(buffer)) > 0) {
     fileOutputStream.write(buffer, 0, len);
    }
    //關(guān)閉流
    fileOutputStream.close();
    inputStream.close();
    msg = "上傳成功";
    fileItem.delete();//上傳成功,清除臨時(shí)文件
   }
  }
  return msg;
}

文件上傳的注意事項(xiàng)

1、為保證服務(wù)器安全,上傳的文件應(yīng)該放在外界無法直接訪問的目錄下,例如放在WEB-INF目錄下。
2、為了防止文件覆蓋的現(xiàn)象,要為上傳的文件產(chǎn)生一個(gè)唯一的文件名(可以為每一個(gè)上傳的文件增加一個(gè)uuid或時(shí)間戳為名的文件夾)
3、限制上傳文件的最大值
4、限制上傳文件的類型,在收到上傳文件時(shí),判斷其后綴名是否合法,是否為自己限制的類型

看完上述內(nèi)容,你們掌握怎么在java項(xiàng)目中實(shí)現(xiàn)一個(gè)文件上傳功能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI