Spring Boot 2.x 實(shí)現(xiàn)文件上傳功能
文件上傳的功能實(shí)現(xiàn)是我們做Web應(yīng)用時(shí)候最為常見的應(yīng)用場(chǎng)景,比如:實(shí)現(xiàn)頭像的上傳,Excel文件數(shù)據(jù)的導(dǎo)入等功能,都需要我們先實(shí)現(xiàn)文件的上傳,然后再做圖片的裁剪,excel數(shù)據(jù)的解析入庫(kù)等后續(xù)操作。
今天通過這篇文章,我們就來(lái)一起學(xué)習(xí)一下如何在Spring Boot中實(shí)現(xiàn)文件的上傳。
動(dòng)手試試第一步:創(chuàng)建一個(gè)基礎(chǔ)的Spring Boot項(xiàng)目,如果還不會(huì)的話就先看看這篇《快速入門》。
第二步:在pom.xml中引入模版引擎依賴:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId></dependency>
你也可以選擇其他你熟悉的模版引擎,比如:Freemarker。
第三步:在resources目錄下,創(chuàng)建新目錄templates;在templates目錄下再創(chuàng)建一個(gè)文件上傳的頁(yè)面upload.html,內(nèi)容如下:
<!DOCTYPE html><html><head lang='en'> <meta charset='UTF-8' /> <title>文件上傳頁(yè)面</title></head><body><h1>文件上傳頁(yè)面</h1><form method='post' action='/upload' enctype='multipart/form-data'> 選擇要上傳的文件:<input type='file' name='file'><br> <hr> <input type='submit' value='提交'></form></body></html>
第四步:創(chuàng)建文件上傳的處理控制器,命名為UploadController
@Controller@Slf4jpublic class UploadController { @Value('${file.upload.path}') private String path; @GetMapping('/') public String uploadPage() { return 'upload'; } @PostMapping('/upload') @ResponseBody public String create(@RequestPart MultipartFile file) throws IOException { String fileName = file.getOriginalFilename(); String filePath = path + fileName; File dest = new File(filePath); Files.copy(file.getInputStream(), dest.toPath()); return 'Upload file success : ' + dest.getAbsolutePath(); }}
其中包含這幾個(gè)重要元素:
成員變量path,通過@Value注入配置文件中的file.upload.path屬性。這個(gè)配置用來(lái)定義文件上傳后要保存的目錄位置。 GET請(qǐng)求,路徑/,用于顯示upload.html這個(gè)文件上傳頁(yè)面。 POST請(qǐng)求。路徑/upload,用于處理上傳的文件,即:保存到file.upload.path配置的路徑下面。注意:這里主要演示文件上傳的主要流程,真實(shí)應(yīng)用還有更多內(nèi)容要考慮,比如:文件上傳后的文件名處理(防止重名)、分布式情況下文件上傳后如何共享訪問等。更高級(jí)的最后,我們后續(xù)文章繼續(xù)講。
第五步:編輯application.properties配置文件
spring.servlet.multipart.max-file-size=2MBspring.servlet.multipart.max-request-size=2MBfile.upload.path=/Users/didi/
前兩個(gè)參數(shù)用于限制了上傳請(qǐng)求和上傳文件的大小,而file.upload.path是上面我們自己定義的用來(lái)保存上傳文件的路徑。
測(cè)試驗(yàn)證第一步:?jiǎn)?dòng)Spring Boot應(yīng)用,訪問http://localhost:8080,可以看到如下的文件上傳頁(yè)面。
第二步:選擇一個(gè)不大于2MB的文件,點(diǎn)擊“提交”按鈕,完成上傳。
如果上傳成功,將顯示類似下面的頁(yè)面:
你可以根據(jù)打印的文件路徑去查看文件是否真的上傳了。
代碼示例
本文的相關(guān)例子可以查看下面?zhèn)}庫(kù)中的chapter4-3目錄:
Github:https://github.com/dyc87112/SpringBoot-Learning/
Gitee:https://gitee.com/didispace/SpringBoot-Learning/
到此這篇關(guān)于Spring Boot 2.x 實(shí)現(xiàn)文件上傳功能的文章就介紹到這了,更多相關(guān)Spring Boot 2.x 實(shí)現(xiàn)文件上傳內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. div的offsetLeft與style.left區(qū)別2. 不要在HTML中濫用div3. html清除浮動(dòng)的6種方法示例4. 前端html+css實(shí)現(xiàn)動(dòng)態(tài)生日快樂代碼5. CSS代碼檢查工具stylelint的使用方法詳解6. 詳解CSS偽元素的妙用單標(biāo)簽之美7. WML語(yǔ)言的基本情況8. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)9. 使用css實(shí)現(xiàn)全兼容tooltip提示框10. 利用CSS3新特性創(chuàng)建透明邊框三角
