java基于spring boot本地上傳圖片示例解析
前幾天項目中剛好需要上傳圖片的需求,當(dāng)時想的是用七牛云,因為我用七牛云也用了好幾次,就是把圖片上傳到七牛云空間里面,數(shù)據(jù)庫里面保存的是這張上傳圖片的url地址 那么頁面訪問也就很方便,考慮到項目部署的環(huán)境我就用了本地上傳,不牽涉數(shù)據(jù)庫的操作。我就花了半個小時寫了個本地上傳圖片的小demo。非常的簡單。
下面是需要的依賴 pom.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>cn.com.sctic</groupId>
<artifactId>upload</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>upload</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
控制器: UploadController
@Controller
public class UploadController {
private Logger logger = LoggerFactory.getLogger(this.getClass());
@Value("${scitc.upload.src}")
private String rootPath;
@Value("${scitc.upload.host}")
private String uploadhost;
@RequestMapping(value = "/uploadFile",method = {RequestMethod.POST,RequestMethod.GET})
@ResponseBody
public String uploadFile(MultipartFile file) {
//文件的完整名稱,如spring.jpeg
String filename = file.getOriginalFilename();
//文件名,如spring
String name = filename.substring(0,filename.indexOf("."));
//文件后綴,如.jpeg
String suffix = filename.substring(filename.lastIndexOf("."));
//創(chuàng)建年月文件夾
Calendar date = Calendar.getInstance();
File dateDirs = new File(date.get(Calendar.YEAR)
+ File.separator + (date.get(Calendar.MONTH)+1));
//目標(biāo)文件
File descFile = new File(rootPath+File.separator+dateDirs+File.separator+filename);
int i = 1;
//若文件存在重命名
String newFilename = filename;
while(descFile.exists()) {
newFilename = name+"("+i+")"+suffix;
String parentPath = descFile.getParent();
descFile = new File(parentPath+File.separator+newFilename);
i++;
}
//判斷目標(biāo)文件所在的目錄是否存在
if(!descFile.getParentFile().exists()) {
//如果目標(biāo)文件所在的目錄不存在,則創(chuàng)建父目錄
descFile.getParentFile().mkdirs();
}
//將內(nèi)存中的數(shù)據(jù)寫入磁盤
try {
file.transferTo(descFile);
} catch (Exception e) {
e.printStackTrace();
logger.error("上傳失敗,cause:{}",e);
}
//完整的url
String fileUrl = uploadhost + rootPath +dateDirs+ "/"+newFilename;
return "success:" + fileUrl;
}
}
注意:rootPath,uploadhost是可以通過application.properties或者application.yml進行配置的。
由于要對外部資源進行映射需要創(chuàng)建一個類繼承WebMvcConfigurationSupport這個適配器,下面是WebMvcConfigurer的這個配置類,代碼如下:
@Configuration
public class WebMvcConfigurer extends WebMvcConfigurationSupport {
@Value("${scitc.upload.src}")
private String src;
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler(src + "/**").addResourceLocations("file:" + src);
}
}
注意:這里的src也是從配置文件applicaiton.properties中得到了。
下面是application.properties配置:
server.port=8848
##文件上傳config
scitc.upload.host:127.0.0.1:${server.port}
scitc.upload.src=/Users/jswzj/Desktop/uploads/
spring.servlet.multipart.maxFileSize=10MB
spring.servlet.multipart.maxRequestSize=10MB
server.port=8848 服務(wù)器的端口號
scitc.upload.host:服務(wù)器ip地址 + server.port
scitc.upload.src:你要把用戶上傳的圖片上傳到那個位置**
最后我們訪問這個接口效果圖如下:

上傳成功后拿到這個url地址 粘貼到瀏覽器地址上就能訪問了

總結(jié):圖片上傳有很多的方式,當(dāng)然這個是根據(jù)業(yè)務(wù)的需求,很多人都喜歡把圖片的url上傳到數(shù)據(jù)庫中,用實體類來對圖片的高度、寬度、名稱、url進行封裝,我覺得如果你部署的那臺服務(wù)器是有網(wǎng)絡(luò)的環(huán)境下建議用七牛云上傳,七牛云上傳把圖片保存到七牛云空間,那個url地址是不會發(fā)生變化的,不會應(yīng)為你項目的遷移或者服務(wù)器地址發(fā)生變化而受影響??锤髯缘男枨蟀伞5扔袝r間我會出一個七牛云上傳的demo讓大家學(xué)習(xí)。最后謝謝大家的支持,希望大家每天都要收獲。祝大家早日成為大神。
下面是這個demo的github的地址,希望大家fork,start一下,謝謝
https://github.com/zhoubiao188/springboot-upload
到此這篇關(guān)于java基于spring boot本地上傳圖片示例解析的文章就介紹到這了,更多相關(guān)spring boot本地上傳圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中Tomcat和SpringMVC整合源碼分析
Tomcat和SpringMVC都是通過這樣的方式進行集成的,SpringBoot出現(xiàn)之前SpringMVC項目是直接部署在Tomcat服務(wù)器中的,這篇文章主要介紹了SpringBoot中Tomcat和SpringMVC整合源碼分析,需要的朋友可以參考下2022-07-07
用SpringBoot Admin監(jiān)控SpringBoot程序
這篇文章主要介紹了用SpringBoot Admin監(jiān)控SpringBoot程序,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-10-10
IntelliJ IDEA修改內(nèi)存大小,使得idea運行更流暢
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA修改內(nèi)存大小,使得idea運行更流暢的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10
新手學(xué)習(xí)JQuery基本操作和使用案例解析
這篇文章主要介紹了新手學(xué)習(xí)JQuery基本操作和使用案例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-02-02

