【Springboot】springboot中上傳圖片的訪問不了,配置虛擬化路徑解決(后端)


在springboot中,上傳圖片或文件上傳成功后,卻無法訪問。

在springboot中,用相對的路徑儲存,也只是存儲在臨時的目錄,一重啟文件就會沒有了。並且打為jar后,存入文件也會有問題。

這時,需要配置一個虛擬路徑,映射到物理路徑上。比如在服務器將文件存在/usr/upload文件夾下,同時映射的路徑為http://localhost:8080/image。那么處理上傳文件的后台程序則寫入文件/usr/upload文件夾下,通過瀏覽器訪問localhost:8080/image/xxx.png,就相當於訪問/usr/upload文件夾的xxx.png。

具體的實現步驟-》

前端使用的參考博客園,使用的是TinyMCE編輯器。粘貼圖片,就可以上傳。

這個異步不是使用form,所以不討論上傳的工具類。

在后端中,處理上傳的handler:

package com.hj.blog.handler;

import com.hj.blog.service.UploadService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import java.io.*;

@RestController
public class UploadHandler {
    private Logger logger = LoggerFactory.getLogger(UploadHandler.class);
    @Autowired
    private UploadService uploadService;

    @RequestMapping("/uploadimg")
    public String uploadimg(HttpServletRequest request) throws IOException, ServletException {
        // handler調用文件上傳的service 得到文件的虛擬路徑
        String filepath = uploadService.uploadImg(request);
        return filepath;
    }

}

處理文件上傳的service,在service中將上傳的文件夾和映射的文件夾都放在配置文件中:

package com.hj.blog.service;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import java.io.*;
import java.text.SimpleDateFormat;
import java.util.*;

@Service
public class UploadService {
    private Logger logger = LoggerFactory.getLogger(UploadService.class);
    // 文件的真實路徑
    @Value("${file.uploadFolder}")
    private String realBasePath;
    @Value("${file.accessPath}")
    private String accessPath;

    public String uploadImg(HttpServletRequest request) throws IOException, ServletException {
        InputStream inputStream = request.getInputStream();
        //獲取請求頭中Contect-Type的值
        // 圖片后綴
        String imgSuffix = "png";
        Enumeration enumeration=request.getHeaderNames();
        while(enumeration.hasMoreElements()) {
            String name=(String)enumeration.nextElement();
            if(name.equals("content-type")){
                String value=request.getHeader(name);
                imgSuffix = value.split("/")[1];
                logger.info("header中" + name + " " + value);
                logger.info("文件后綴:" + imgSuffix);
            }
        }
        // 文件唯一的名字
        String fileName = UUID.randomUUID().toString() + "." +imgSuffix;
        Date todayDate = new Date();
        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
        String today = dateFormat.format(todayDate);
        // 域名訪問的相對路徑(通過瀏覽器訪問的鏈接-虛擬路徑)
        String saveToPath = accessPath + today + "/";
        // 真實路徑,實際儲存的路徑
        String realPath = realBasePath + today + "/";
        // 儲存文件的物理路徑,使用本地路徑儲存
        String filepath = realPath + fileName;
        logger.info("上傳圖片名為:" + fileName+"--虛擬文件路徑為:" + saveToPath +"--物理文件路徑為:" + realPath);
        // 判斷有沒有對應的文件夾
        File destFile = new File(filepath);
        if (!destFile.getParentFile().exists()) {
            destFile.getParentFile().mkdirs();
        }
        // 輸出流 輸出到文件
        OutputStream outputStream = new FileOutputStream(destFile);
        // 緩沖區
        byte[] bs = new byte[1024];
        int len = -1;
        while ((len = inputStream.read(bs)) != -1) {
            outputStream.write(bs,0,len);
        }
        inputStream.close();
        outputStream.close();
        // 返回虛擬路徑,給鏈接訪問
        return saveToPath+fileName;
    }

}

application.properties:

# 上傳的服務器上的映射文件夾
file.accessPath=/uploadimg/
#靜態資源對外暴露的訪問路徑
file.staticAccessPath=/uploadimg/**
#文件上傳目錄(注意Linux和Windows上的目錄結構不同)
#file.uploadFolder=/root/uploadFiles/
file.uploadFolder=C://File_rec/tmp/

關鍵的配置類:

package com.hj.blog.config;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
/**
  * 設置虛擬路徑,訪問絕對路徑下資源
  */
@Configuration
public class UploadConfig implements WebMvcConfigurer{
    @Value("${file.staticAccessPath}")
    private String staticAccessPath;
    @Value("${file.uploadFolder}")
    private String uploadFolder;
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler(staticAccessPath).addResourceLocations("file:" + uploadFolder);
    }
}

 

通過最后的配置類,設置了虛擬的路徑到物理的路徑中。也可以正常的訪問圖片了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM