1. 程式人生 > 程式設計 >java基於spring boot本地上傳圖片示例解析

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

前幾天專案中剛好需要上傳圖片的需求,當時想的是用七牛雲,因為我用七牛雲也用了好幾次,就是把圖片上傳到七牛雲空間裡面,資料庫裡面儲存的是這張上傳圖片的url地址 那麼頁面訪問也就很方便,考慮到專案部署的環境我就用了本地上傳,不牽涉資料庫的操作。我就花了半個小時寫了個本地上傳圖片的小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("."));
  
      //建立年月資料夾
      Calendar date = Calendar.getInstance();
      File dateDirs = new File(date.get(Calendar.YEAR)
          + File.separator + (date.get(Calendar.MONTH)+1));
  
      //目標檔案
      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++;
      }
      //判斷目標檔案所在的目錄是否存在
      if(!descFile.getParentFile().exists()) {
        //如果目標檔案所在的目錄不存在,則建立父目錄
        descFile.getParentFile().mkdirs();
      }
      //將記憶體中的資料寫入磁碟
      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進行配置的。

由於要對外部資源進行對映需要建立一個類繼承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 伺服器的埠號
	   scitc.upload.host:伺服器ip地址 + server.port
	   scitc.upload.src:你要把使用者上傳的圖片上傳到那個位置**

最後我們訪問這個介面效果圖如下:

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

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

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

總結:圖片上傳有很多的方式,當然這個是根據業務的需求,很多人都喜歡把圖片的url上傳到資料庫中,用實體類來對圖片的高度、寬度、名稱、url進行封裝,我覺得如果你部署的那臺伺服器是有網路的環境下建議用七牛雲上傳,七牛雲上傳把圖片儲存到七牛雲空間,那個url地址是不會發生變化的,不會應為你專案的遷移或者伺服器地址發生變化而受影響。看各自的需求吧。等有時間我會出一個七牛雲上傳的demo讓大家學習。最後謝謝大家的支援,希望大家每天都要收穫。祝大家早日成為大神。

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

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

到此這篇關於java基於spring boot本地上傳圖片示例解析的文章就介紹到這了,更多相關spring boot本地上傳圖片內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!