SpringBoot實(shí)現(xiàn)本地存儲(chǔ)文件上傳及提供HTTP訪問(wèn)服務(wù)的方法
筆者計(jì)劃為大家介紹分布式文件系統(tǒng),用于存儲(chǔ)應(yīng)用的圖片、word、excel、pdf等文件。在開(kāi)始介紹分布式文件系統(tǒng)之前,為大家介紹一下使用本機(jī)存儲(chǔ)來(lái)存放文件資源。
二者的核心實(shí)現(xiàn)過(guò)程是一樣的:
- 上傳文件,保存文件(本節(jié)是本地磁盤(pán))
- 返回文件HTTP訪問(wèn)服務(wù)路徑給前端,進(jìn)行上傳之后的效果展示
一、復(fù)習(xí)
服務(wù)端接收上傳的目的是提供文件的訪問(wèn)服務(wù),那么對(duì)于SpringBoot而言,有哪些可以提供文件訪問(wèn)的靜態(tài)資源目錄呢?
classpath:/META-INF/resources/
,classpath:/static/
,classpath:/public/
,classpath:/resources/
這是之前我們?yōu)榇蠹医榻B的內(nèi)容,從這里看出這里的靜態(tài)資源都在classpath下。那么就出現(xiàn)問(wèn)題:
- 應(yīng)用的文件資源不能和項(xiàng)目代碼分開(kāi)存儲(chǔ)(你見(jiàn)過(guò)往github上傳代碼,還附帶項(xiàng)目文件數(shù)據(jù)的么?)
- 項(xiàng)目打包困難,當(dāng)上傳的文件越來(lái)越多,項(xiàng)目的打包jar越來(lái)越大。
- 代碼與文件數(shù)據(jù)不能分開(kāi)存儲(chǔ),就意味著文件數(shù)據(jù)的備份將變得復(fù)雜
二、文件上傳目錄自定義配置
怎么解決上述問(wèn)題?別忘記了spring boot 為我們提供了使用spring.resources.static-locations
配置自定義靜態(tài)文件的位置。
web: upload-path: D:/data/ spring: resources: static-locations: classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/,file:${web.upload-path}
- 配置
web.upload-path
為與項(xiàng)目代碼分離的靜態(tài)資源路徑,即:文件上傳保存根路徑 - 配置
spring.resources.static-locations
,除了帶上Spring Boot默認(rèn)的靜態(tài)資源路徑之外,加上file:${web.upload-path}指向外部的文件資源上傳路徑。該路徑下的靜態(tài)資源可以直接對(duì)外提供HTTP訪問(wèn)服務(wù)。
三、文件上傳的Controller實(shí)現(xiàn)
詳情看代碼注釋
@RestController public class FileUploadController { //綁定文件上傳路徑到uploadPath @Value("${web.upload-path}") private String uploadPath; SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd/"); @PostMapping("/upload") public String upload(MultipartFile uploadFile, HttpServletRequest request) { // 在 uploadPath 文件夾中通過(guò)日期對(duì)上傳的文件歸類保存 // 比如:/2019/06/06/cf13891e-4b95-4000-81eb-b6d70ae44930.png String format = sdf.format(new Date()); File folder = new File(uploadPath + format); if (!folder.isDirectory()) { folder.mkdirs(); } // 對(duì)上傳的文件重命名,避免文件重名 String oldName = uploadFile.getOriginalFilename(); String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."), oldName.length()); try { // 文件保存 uploadFile.transferTo(new File(folder, newName)); // 返回上傳文件的訪問(wèn)路徑 String filePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + format + newName; return filePath; } catch (IOException e) { throw new CustomException(CustomExceptionType.SYSTEM_ERROR); } } }
四、寫(xiě)一個(gè)模擬的文件上傳頁(yè)面,進(jìn)行測(cè)試
把該upload.html文件放到classpath:public目錄下,對(duì)外提供訪問(wèn)。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="uploadFile" value="請(qǐng)選擇上傳文件"> <input type="submit" value="保存"> </form> </body> </html>
訪問(wèn)測(cè)試、點(diǎn)擊“選擇文件”,之后保存
文件被保存到服務(wù)端的web.upload-path
指定的資源目錄下
瀏覽器端響應(yīng)結(jié)果如下,返回一個(gè)文件HTTP訪問(wèn)路徑:
使用該HTTP訪問(wèn)路徑,在瀏覽器端訪問(wèn)效果如下。證明我們的文件已經(jīng)成功上傳到服務(wù)端,以后需要訪問(wèn)該圖片就通過(guò)這個(gè)HTTP URL就可以了。
到此這篇關(guān)于SpringBoot實(shí)現(xiàn)本地存儲(chǔ)文件上傳及提供HTTP訪問(wèn)服務(wù)的文章就介紹到這了,更多相關(guān)SpringBoot實(shí)現(xiàn)文件上傳和訪問(wèn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis中XML 映射文件中常見(jiàn)的標(biāo)簽說(shuō)明
這篇文章主要介紹了MyBatis中XML 映射文件中常見(jiàn)的標(biāo)簽說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07SpringCloud微服務(wù)熔斷器Hystrix使用詳解
這篇文章主要介紹了Spring Cloud Hyxtrix的基本使用,它是Spring Cloud中集成的一個(gè)組件,在整個(gè)生態(tài)中主要為我們提供服務(wù)隔離,服務(wù)熔斷,服務(wù)降級(jí)功能,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07JavaCV調(diào)用百度AI實(shí)現(xiàn)人臉檢測(cè)方法詳解
在檢測(cè)人臉數(shù)量、位置、性別、口罩等場(chǎng)景時(shí),可以考慮使用百度開(kāi)放平臺(tái)提供的web接口,一個(gè)web請(qǐng)求就能完成檢測(cè)得到結(jié)果。本文就為大家介紹JavaCV如何調(diào)用百度AI實(shí)現(xiàn)最簡(jiǎn)單的人臉檢測(cè),需要的可以參考一下2022-01-01SpringBoot參數(shù)校驗(yàn)之@Valid的使用詳解
這篇文章主要通過(guò)示例為大家詳細(xì)介紹一下介紹了SpringBoot參數(shù)校驗(yàn)中@Valid的使用方法,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-06-06