Spring Boot 2.x基礎教程:多個文件的上傳

昨天,咱們介紹瞭如何在Spring Boot中實現文件的上傳。有讀者問:那麼若是有多個文件要同時上傳呢?這就立刻奉上,當碰到多個文件要同時上傳的處理方法。html

動手試試

本文的動手環節將基於Spring Boot中實現文件的上傳一文的例子之上,因此讀者能夠拿上一篇的例子做爲基礎來進行改造,以體會這之間的區別,下面也主要講解核心區別的地方。java

第一步:修改文件上傳頁面的上傳表單git

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8" />
    <title>文件上傳頁面 - didispace.com</title>
</head>
<body>
<h1>文件上傳頁面</h1>
<form method="post" action="/upload" enctype="multipart/form-data">
    文件1:<input type="file" name="files"><br>
    文件2:<input type="file" name="files"><br>
    <hr>
    <input type="submit" value="提交">
</form>
</body>
</html>

能夠看到這裏多增長一個input文件輸入框,同時文件輸入框的名稱修改成了files,由於是多個文件,因此用了複數。注意:這幾個輸入框的name是同樣的,這樣才能在後端處理文件的時候組織到一個數組中。github

第二步:修改後端處理接口spring

@PostMapping("/upload")
@ResponseBody
public String create(@RequestPart MultipartFile[] files) throws IOException {
    StringBuffer message = new StringBuffer();

    for (MultipartFile file : files) {
        String fileName = file.getOriginalFilename();
        String filePath = path + fileName;

        File dest = new File(filePath);
        Files.copy(file.getInputStream(), dest.toPath());
        message.append("Upload file success : " + dest.getAbsolutePath()).append("<br>");
    }
    return message.toString();
}

幾個重要改動:後端

  1. MultipartFile使用數組,參數名稱files對應html頁面中input的name,必定要對應。
  2. 後續處理文件的主體(for循環內)跟以前的同樣,就是對MultipartFile數組經過循環遍歷的方式對每一個文件進行存儲,而後拼接結果返回信息。

更多本系列免費教程連載「點擊進入彙總目錄」數組

測試驗證

第一步:啓動Spring Boot應用,訪問http://localhost:8080,能夠看到以下的文件上傳頁面。app

第二步:選擇2個不大於2MB的文件,點擊「提交」按鈕,完成上傳。spring-boot

若是上傳成功,將顯示相似下面的頁面:post

你能夠根據打印的文件路徑去查看文件是否真的上傳了。

代碼示例

本文的相關例子能夠查看下面倉庫中的chapter4-4目錄:

若是您以爲本文不錯,歡迎Star支持,您的關注是我堅持的動力!

歡迎關注個人公衆號:程序猿DD,得到獨家整理的免費學習資源助力你的Java學習之路!另每週贈書不停哦~
相關文章
相關標籤/搜索