久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

java基于spring boot本地上傳圖片示例解析

瀏覽:4日期:2023-08-26 11:45:53

前幾天項目中剛好需要上傳圖片的需求,當(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:你要把用戶上傳的圖片上傳到那個位置**

最后我們訪問這個接口效果圖如下:

java基于spring boot本地上傳圖片示例解析

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

java基于spring boot本地上傳圖片示例解析

總結(jié):圖片上傳有很多的方式,當(dāng)然這個是根據(jù)業(yè)務(wù)的需求,很多人都喜歡把圖片的url上傳到數(shù)據(jù)庫中,用實體類來對圖片的高度、寬度、名稱、url進行封裝,我覺得如果你部署的那臺服務(wù)器是有網(wǎng)絡(luò)的環(huán)境下建議用七牛云上傳,七牛云上傳把圖片保存到七牛云空間,那個url地址是不會發(fā)生變化的,不會應(yīng)為你項目的遷移或者服務(wù)器地址發(fā)生變化而受影響。看各自的需求吧。等有時間我會出一個七牛云上傳的demo讓大家學(xué)習(xí)。最后謝謝大家的支持,希望大家每天都要收獲。祝大家早日成為大神。

下面是這個demo的github的地址,希望大家fork,start一下,謝謝

https://github.com/zhoubiao188/springboot-upload

到此這篇關(guān)于java基于spring boot本地上傳圖片示例解析的文章就介紹到這了,更多相關(guān)spring boot本地上傳圖片內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国户精品久久久久久久久久久不卡 | www312aⅴ欧美在线看 | 国产精品99久久久久久动医院 | 精品久久国产 | 免费看爱爱视频 | 91在线播放视频 | 久久爱电影| 国产日韩欧美激情 | 五月激情六月婷婷 | 亚洲一区av在线 | 一级h片 | 日韩成人影院 | 精品国产高清一区二区三区 | 九九综合 | 成人1区2区 | 亚洲国产精品久久久久秋霞不卡 | 欧美中文一区 | 簧片免费网站 | 黄色a视频 | 国产一区二区在线免费观看 | 在线成人免费视频 | 亚洲无吗视频 | 亚洲少妇视频 | 欧美区视频 | 久草免费在线视频 | 亚洲永久 | 在线视频一区二区三区 | 日韩极品在线 | av国产精品毛片一区二区小说 | 久久成人久久爱 | 欧洲国产伦久久久久久久 | 成人在线观看中文字幕 | 蜜桃视频麻豆女神沈芯语免费观看 | 色天天综合网 | 波多野结衣一二三四区 | 日韩一区二区三区在线观看 | 国产欧美精选 | 冷水浴在线观看 | 中文字幕综合 | 亚洲乱码一区二区三区在线观看 | 久久久中文字幕 |