SpringCloud實現文件上傳功能的方法詳解
圖片上傳
剛才的新增實現中,我們並沒有上傳圖片,接下來我們一起完成圖片上傳邏輯。
文件的上傳並不隻是在品牌管理中有需求,以後的其它服務也可能需要,因此我們創建一個獨立的微服務,專門處理各種上傳。
搭建項目
創建SpringCloud項目
添加依賴
我們需要EurekaClient和web依賴:
<?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"> <parent> <artifactId>leyou</artifactId> <groupId>com.leyou.parent</groupId> <version>1.0.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <groupId>com.leyou.service</groupId> <artifactId>ly-upload</artifactId> <version>1.0.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> </dependencies> </project>
編寫配置
server: port: 8082 spring: application: name: upload-service servlet: multipart: max-file-size: 5MB # 限制文件上傳的大小 # Eureka eureka: client: service-url: defaultZone: http://127.0.0.1:10086/eureka instance: lease-renewal-interval-in-seconds: 5 # 每隔5秒發送一次心跳 lease-expiration-duration-in-seconds: 10 # 10秒不發送就過期 prefer-ip-address: true ip-address: 127.0.0.1 instance-id: ${spring.application.name}:${server.port}
需要註意的是,我們應該添加瞭限制文件大小的配置
2.1.4.啟動類
@SpringBootApplication @EnableDiscoveryClient public class LyUploadService { public static void main(String[] args) { SpringApplication.run(LyUploadService.class, args); } }
結構:
編寫上傳功能
controller
編寫controller需要知道4個內容:
- 請求方式:上傳肯定是POST
- 請求路徑:/upload/image
- 請求參數:文件,參數名是file,SpringMVC會封裝為一個接口:MultipleFile
- 返回結果:上傳成功後得到的文件的url路徑
代碼如下:
package com.leyou.upload.web; import com.leyou.upload.service.UploadService; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile; @RestController @RequestMapping("upload") public class UploadController { @Autowired private UploadService uploadService; /** * 上傳圖片功能 * @param file * @return */ @PostMapping("image") public ResponseEntity<String> uploadImage(@RequestParam("file") MultipartFile file){ String url = uploadService.uploadImage(file); if(StringUtils.isBlank(url)){ // url為空,證明上傳失敗 return new ResponseEntity<>(HttpStatus.BAD_REQUEST); } // 返回200,並且攜帶url路徑 return ResponseEntity.ok(url); } }
service
在上傳文件過程中,我們需要對上傳的內容進行校驗:
- 校驗文件大小
- 校驗文件的媒體類型
- 校驗文件的內容
文件大小在Spring的配置文件中設置,因此已經會被校驗,我們不用管。
具體代碼:
package com.leyou.upload.service; import com.leyou.common.enums.ExceptionEnum; import com.leyou.common.exception.LyException; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; import javax.imageio.ImageIO; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import java.util.Arrays; import java.util.List; @Service @Slf4j public class UploadService { private static final List<String> ALLOW_TYPES = Arrays.asList("image/png", "image/jpeg", "image/bmg"); public String uploadImage(MultipartFile file) { try { //校驗文件類型 String contentType = file.getContentType(); if(!ALLOW_TYPES.contains(contentType)){ throw new LyException(ExceptionEnum.INVALID_FILE_TYPE); } //校驗文件的內容 BufferedImage image = ImageIO.read(file.getInputStream()); if(image == null){ throw new LyException(ExceptionEnum.INVALID_FILE_TYPE); } //準備目標路徑 File dest = new File("E:\黑馬程序員57期\09 微服務電商【黑馬樂優商城】\upload\",file.getOriginalFilename()); file.transferTo(dest); //返回路徑 return "http://image.leyou.com/"+file.getOriginalFilename(); } catch (IOException e) { log.error("上傳文件失敗",e); throw new LyException(ExceptionEnum.UPLOAD_FILE_ERROR); } } }
這裡有一個問題:為什麼圖片地址需要使用另外的url?
圖片不能保存在服務器內部,這樣會對服務器產生額外的加載負擔
一般靜態資源都應該使用獨立域名,這樣訪問靜態資源時不會攜帶一些不必要的cookie,減小請求的數據量
測試上傳
我們通過RestClient工具來測試:
結果:
去目錄下查看:
上傳成功!
到此這篇關於SpringCloud實現文件上傳功能的方法詳解的文章就介紹到這瞭,更多相關SpringCloud文件上傳內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- springcloud如何使用Feign後臺內部傳遞MultipartFile
- springboot實現mock平臺的示例代碼
- Feign之Multipartfile文件傳輸填坑
- 如何創建SpringBoot項目
- SpringCloud學習筆記之OpenFeign進行服務調用