Spring Boot(十七):使用 Spring Boot 上傳文件

上傳文件是互聯網中經常應用的場景之一,最典型的狀況就是上傳頭像等,今天就帶着帶着你們作一個 Spring Boot 上傳文件的小案例。html

一、pom 包配置

咱們使用 Spring Boot 版本 2.1.0、jdk 1.八、tomcat 8.0。前端

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.0.RELEASE</version>
</parent>

<properties>
    <java.version>1.8</java.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>
</dependencies>

引入了spring-boot-starter-thymeleaf作頁面模板引擎,寫一些簡單的上傳示例。java

二、啓動類設置

@SpringBootApplication
public class FileUploadWebApplication {

    public static void main(String[] args) throws Exception {
        SpringApplication.run(FileUploadWebApplication.class, args);
    }

    @Bean
    public TomcatServletWebServerFactory tomcatEmbedded() {
        TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory();
        tomcat.addConnectorCustomizers((TomcatConnectorCustomizer) connector -> {
            if ((connector.getProtocolHandler() instanceof AbstractHttp11Protocol<?>)) {
                //-1 means unlimited
                ((AbstractHttp11Protocol<?>) connector.getProtocolHandler()).setMaxSwallowSize(-1);
            }
        });
        return tomcat;
    }

}

tomcatEmbedded 這段代碼是爲了解決,上傳文件大於10M出現鏈接重置的問題。此異常內容 GlobalException 也捕獲不到。git

詳細內容參考:Tomcat large file upload connection resetgithub

三、編寫前端頁面

上傳頁面web

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<body>
<h1>Spring Boot file upload example</h1>
<form method="POST" action="/upload" enctype="multipart/form-data">
    <input type="file" name="file" /><br/><br/>
    <input type="submit" value="Submit" />
</form>
</body>
</html>

很是簡單的一個 Post 請求,一個選擇框選擇文件,一個提交按鈕,效果以下:spring

上傳結果展現頁面:tomcat

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<body>
<h1>Spring Boot - Upload Status</h1>
<div th:if="${message}">
    <h2 th:text="${message}"/>
</div>
</body>
</html>

效果圖以下:app

四、編寫上傳控制類

訪問 localhost 自動跳轉到上傳頁面:spring-boot

@GetMapping("/")
public String index() {
    return "upload";
}

上傳業務處理

@PostMapping("/upload") 
public String singleFileUpload(@RequestParam("file") MultipartFile file,
                               RedirectAttributes redirectAttributes) {
    if (file.isEmpty()) {
        redirectAttributes.addFlashAttribute("message", "Please select a file to upload");
        return "redirect:uploadStatus";
    }

    try {
        // Get the file and save it somewhere
        byte[] bytes = file.getBytes();
        Path path = Paths.get(UPLOADED_FOLDER + file.getOriginalFilename());
        Files.write(path, bytes);

        redirectAttributes.addFlashAttribute("message",
                "You successfully uploaded '" + file.getOriginalFilename() + "'");

    } catch (IOException e) {
        e.printStackTrace();
    }

    return "redirect:/uploadStatus";
}

上面代碼的意思就是,經過MultipartFile讀取文件信息,若是文件爲空跳轉到結果頁並給出提示;若是不爲空讀取文件流並寫入到指定目錄,最後將結果展現到頁面。

MultipartFile是Spring上傳文件的封裝類,包含了文件的二進制流和文件屬性等信息,在配置文件中也可對相關屬性進行配置,基本的配置信息以下:

  • spring.http.multipart.enabled=true #默認支持文件上傳.
  • spring.http.multipart.file-size-threshold=0 #支持文件寫入磁盤.
  • spring.http.multipart.location=# 上傳文件的臨時目錄
  • spring.http.multipart.max-file-size=1Mb # 最大支持文件大小
  • spring.http.multipart.max-request-size=10Mb # 最大支持請求大小

最經常使用的是最後兩個配置內容,限制文件上傳大小,上傳時超過大小會拋出異常:

更多配置信息參考這裏:Common application properties

五、異常處理

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(MultipartException.class)
    public String handleError1(MultipartException e, RedirectAttributes redirectAttributes) {
        redirectAttributes.addFlashAttribute("message", e.getCause().getMessage());
        return "redirect:/uploadStatus";
    }
}

設置一個@ControllerAdvice用來監控Multipart上傳的文件大小是否受限,當出現此異常時在前端頁面給出提示。利用@ControllerAdvice能夠作不少東西,好比全局的統一異常處理等,感興趣的同窗能夠下來了解。

六、總結

這樣一個使用 Spring Boot 上傳文件的簡單 Demo 就完成了,感興趣的同窗能夠將示例代碼下載下來試試吧。

文章內容已經升級到 Spring Boot 2.x

示例代碼-github

示例代碼-碼雲

參考

Spring Boot file upload example

相關文章
相關標籤/搜索