您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“SpringBoot2如何基于Yml配置方式實現文件上傳邏輯”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“SpringBoot2如何基于Yml配置方式實現文件上傳邏輯”這篇文章吧。
文件上傳是項目開發中一個很常用的功能,常見的如頭像上傳,各類文檔數據上傳等。SpringBoot使用MultiPartFile接收來自表單的file文件,然后執行上傳文件。該案例基于SpringBoot2.0中yml配置,管理文件上傳的常見屬性。該案例演示單文件上傳和多文件上傳。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>
<!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <body> <hr/> <h4>1、單文件上傳</h4> <form method="POST" action="/upload1" enctype="multipart/form-data"> 上傳人:<input type="text" name="userName" /><br/> 文件一:<input type="file" name="file" /><br/> <input type="submit" value="Submit" /> </form> <hr/> <h4>2、多文件上傳</h4> <form method="POST" action="/upload2" enctype="multipart/form-data"> 上傳人:<input type="text" name="userName" /><br/> 文件一:<input type="file" name="file" /><br/> 文件二:<input type="file" name="file" /><br/><br/> <input type="submit" value="Submit" /> </form> </body> </html> <hr/>
import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; @Controller public class PageController { /** * 上傳頁面 */ @GetMapping("/uploadPage") public String uploadPage (){ return "upload" ; } }
上傳文件單個限制
max-file-size: 5MB
上傳文件總大小限制
max-request-size: 6MB
spring: application: # 應用名稱 name: node14-boot-file servlet: multipart: # 啟用 enabled: true # 上傳文件單個限制 max-file-size: 5MB # 總限制 max-request-size: 6MB
如果單個文件大小超出1MB,拋出異常
FileSizeLimitExceededException:
如果上傳文件總大小超過6MB,拋出異常
SizeLimitExceededException:
這樣就完全驗證了YML文件中的配置,有效且正確。
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletRequest; import java.io.File; import java.util.Map; @RestController public class FileController { private static final Logger LOGGER = LoggerFactory.getLogger(FileController.class) ; /** * 測試單個文件上傳 */ @RequestMapping("/upload1") public String upload1 (HttpServletRequest request, @RequestParam("file") MultipartFile file){ Map<String, String[]> paramMap = request.getParameterMap() ; if (!paramMap.isEmpty()){ LOGGER.info("paramMap == >>{}",paramMap); } try{ if (!file.isEmpty()){ // 打印文件基礎信息 LOGGER.info("Name == >>{}",file.getName()); LOGGER.info("OriginalFilename == >>{}",file.getOriginalFilename()); LOGGER.info("ContentType == >>{}",file.getContentType()); LOGGER.info("Size == >>{}",file.getSize()); // 文件輸出地址 String filePath = "F:/boot-file/" ; new File(filePath).mkdirs(); File writeFile = new File(filePath, file.getOriginalFilename()); file.transferTo(writeFile); } return "success" ; } catch (Exception e){ e.printStackTrace(); return "系統異常" ; } } /** * 測試多文件上傳 */ @RequestMapping("/upload2") public String upload2 (HttpServletRequest request, @RequestParam("file") MultipartFile[] fileList){ Map<String, String[]> paramMap = request.getParameterMap() ; if (!paramMap.isEmpty()){ LOGGER.info("paramMap == >>{}",paramMap); } try{ if (fileList.length > 0){ for (MultipartFile file:fileList){ // 打印文件基礎信息 LOGGER.info("Name == >>{}",file.getName()); LOGGER.info("OriginalFilename == >>{}",file.getOriginalFilename()); LOGGER.info("ContentType == >>{}",file.getContentType()); LOGGER.info("Size == >>{}",file.getSize()); // 文件輸出地址 String filePath = "F:/boot-file/" ; new File(filePath).mkdirs(); File writeFile = new File(filePath, file.getOriginalFilename()); file.transferTo(writeFile); } } return "success" ; } catch (Exception e){ return "fail" ; } } }
以上是“SpringBoot2如何基于Yml配置方式實現文件上傳邏輯”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。