SpringBoot 項目中的圖片處理策略之本地存儲與路徑映射
一、前言
在做網頁的時候,會經常遇到一個問題,那就是如何在前端訪問圖片,還有就是圖片應該如何存?存在數據庫,然后直接把文件發(fā)給前端?數據庫表示:“哥們你可真行,我快裝不下了”。比較好一點的做法就是把圖片存在本地*(ps:這里不考慮云存儲)*,然后數據庫存該文件的路徑。這樣一來前端如何訪問這個文件呢?我們都知道在SpringBoot項目中,靜態(tài)資源都存放在static目錄下,使得前端可以通過URL來訪問這些資源,現在我們就需要將文件系統(tǒng)的文件路徑與 URL 建立一個映射關系,把文件系統(tǒng)中的文件當成我們的靜態(tài)資源即可。下面開始演示:
二、演示
本篇的重點是如何通過 URL 來訪問服務器的文件系統(tǒng)中的文件,這里就不使用數據庫了。
- 我們創(chuàng)建一個
SpringBoot項目,依賴如下:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>- 在
static目錄下,我們可以直接通過URL來訪問,該目錄下有一個/image/avatar.png文件


我們現在的目標是:假設在D/image目錄下有一個圖片,如何直接通過URL來訪問本地文件呢?
- 在
application.properties配置文件中定義圖片存放的位置
# 圖片保存路勁 imagepath=D:/image/
- 創(chuàng)建一個類實現
WebMvcConfigurer接口并重寫addResourceHandlers方法。
@Configuration
public class InterceptorConfig implements WebMvcConfigurer {
@Value("${imagepath}")
private String imagePath;//從配置文件中獲取文件路徑
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/image/**")
.addResourceLocations("file:" + imagePath);
}
}addResourceHandler("/image/**"):定義了一個URL模式,即以"/image/"開頭的請求路徑。任何匹配該模式的請求都將被映射到相應的靜態(tài)資源。.addResourceLocations("file:" + imagepath):指定了實際存儲靜態(tài)資源的文件系統(tǒng)路徑,"file:"前綴告訴Spring MVC,這是一個文件系統(tǒng)路徑。- 這段代碼的作用是告訴
Spring MVC,當接收到以"/image/"開頭的請求時,去指定的文件系統(tǒng)路徑imagepath(D/image/)查找對應的靜態(tài)資源。例如:當請求"/image/test.jpg"時,Spring MVC將會嘗試在"D/image/"目錄下查找并返回"test.jpg"這個文件作為響應。
- 在
"D/image/"下保存一個圖片

- 訪問
http://localhost:8080/image/test.png

可以看到映射成功了,其實在數據庫中存的就是"/image/"+imageName。如果你要將項目部署到Linux服務器上,需要把文件目錄修改成Linux系統(tǒng)的,比如:
imagepath=/root/soft/images/
到此這篇關于SpringBoot 項目中的圖片處理策略:本地存儲與路徑映射的文章就介紹到這了,更多相關SpringBoot 本地存儲與路徑映射內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
maven中no main manifest attribute的問題解決
本文主要介紹了maven中no main manifest attribute的問題解決,這個錯誤通常意味著Spring Boot應用在啟動時遇到了問題,下面就來具體介紹一下,感興趣的可以了解一下2024-08-08
Spring Aop之AspectJ注解配置實現日志管理的方法
下面小編就為大家分享一篇Spring Aop之AspectJ注解配置實現日志管理的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Hadoop MultipleOutputs輸出到多個文件中的實現方法
這篇文章主要介紹了 Hadoop MultipleOutputs輸出到多個文件中的實現方法的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-10-10
Spring動態(tài)修改bean屬性配置key的幾種方法
在Spring應用開發(fā)中,我們經常需要從配置文件讀取屬性值并注入到bean中,但是你有沒有遇到過這種情況:某個bean的屬性需要根據運行環(huán)境動態(tài)切換配置key? 比如測試環(huán)境和生產環(huán)境使用不同的數據庫配置前綴?今天我們就來探討這個看似簡單卻經常讓人頭疼的問題2025-04-04

