java基于spring boot本地上傳圖片示例解析
前幾天項(xiàng)目中剛好需要上傳圖片的需求,當(dāng)時(shí)想的是用七牛云,因?yàn)槲矣闷吲T埔灿昧撕脦状?就是把圖片上傳到七牛云空間里面,數(shù)據(jù)庫里面保存的是這張上傳圖片的url地址 那么頁面訪問也就很方便,考慮到項(xiàng)目部署的環(huán)境我就用了本地上傳,不牽涉數(shù)據(jù)庫的操作。我就花了半個(gè)小時(shí)寫了個(gè)本地上傳圖片的小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進(jìn)行配置的。
由于要對(duì)外部資源進(jìn)行映射需要?jiǎng)?chuàng)建一個(gè)類繼承WebMvcConfigurationSupport這個(gè)適配器,下面是WebMvcConfigurer的這個(gè)配置類,代碼如下:
@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ù)器的端口號(hào) scitc.upload.host:服務(wù)器ip地址 + server.port scitc.upload.src:你要把用戶上傳的圖片上傳到那個(gè)位置**
最后我們?cè)L問這個(gè)接口效果圖如下:
上傳成功后拿到這個(gè)url地址 粘貼到瀏覽器地址上就能訪問了
總結(jié):圖片上傳有很多的方式,當(dāng)然這個(gè)是根據(jù)業(yè)務(wù)的需求,很多人都喜歡把圖片的url上傳到數(shù)據(jù)庫中,用實(shí)體類來對(duì)圖片的高度、寬度、名稱、url進(jìn)行封裝,我覺得如果你部署的那臺(tái)服務(wù)器是有網(wǎng)絡(luò)的環(huán)境下建議用七牛云上傳,七牛云上傳把圖片保存到七牛云空間,那個(gè)url地址是不會(huì)發(fā)生變化的,不會(huì)應(yīng)為你項(xiàng)目的遷移或者服務(wù)器地址發(fā)生變化而受影響。看各自的需求吧。等有時(shí)間我會(huì)出一個(gè)七牛云上傳的demo讓大家學(xué)習(xí)。最后謝謝大家的支持,希望大家每天都要收獲。祝大家早日成為大神。
下面是這個(gè)demo的github的地址,希望大家fork,start一下,謝謝
https://github.com/zhoubiao188/springboot-upload
到此這篇關(guān)于java基于spring boot本地上傳圖片示例解析的文章就介紹到這了,更多相關(guān)spring boot本地上傳圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中Tomcat和SpringMVC整合源碼分析
Tomcat和SpringMVC都是通過這樣的方式進(jìn)行集成的,SpringBoot出現(xiàn)之前SpringMVC項(xiàng)目是直接部署在Tomcat服務(wù)器中的,這篇文章主要介紹了SpringBoot中Tomcat和SpringMVC整合源碼分析,需要的朋友可以參考下2022-07-07java隨機(jī)數(shù)生產(chǎn)算法實(shí)例
下面小編就為大家?guī)硪黄猨ava隨機(jī)數(shù)生產(chǎn)算法實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10用SpringBoot Admin監(jiān)控SpringBoot程序
這篇文章主要介紹了用SpringBoot Admin監(jiān)控SpringBoot程序,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-10-10Mybatis實(shí)現(xiàn)分頁查詢的詳細(xì)流程
這篇文章主要給大家介紹了關(guān)于Mybatis實(shí)現(xiàn)分頁查詢的詳細(xì)流程,MyBatis是支持普通SQL查詢,存儲(chǔ)過程和高級(jí)映射的優(yōu)秀持久層框架,需要的朋友可以參考下2023-08-08IntelliJ IDEA修改內(nèi)存大小,使得idea運(yùn)行更流暢
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA修改內(nèi)存大小,使得idea運(yùn)行更流暢的文章,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-10-10新手學(xué)習(xí)JQuery基本操作和使用案例解析
這篇文章主要介紹了新手學(xué)習(xí)JQuery基本操作和使用案例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02