Springboot上传文件到Linux服务器

本文档详细介绍了SpringBoot项目中如何配置文件上传路径,通过映射访问图片,并提供上传方法及配置类示例。配置包括本地和服务器地址,文件上传后动态命名并保存,以及通过映射在页面展示图片。同时,讨论了静态资源映射的两种方式,推荐使用配置类方式避免与Swagger冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jar打包方式不支持将文件动态写入文件,这时需要通过映射的方式将文件上传到映射某一个文件夹,通过映射获取文件,在页面显示。

1.yml配置

  • 配置本地上传地址或者服务器地址,springboot项目可以通过映射获取文件,从而页面显示
  • 注意:这里配置的地址一定要加一个"/"在最后面!!!!
file:
  #服务器地址
  uploadurl: "/u01/upload/images/"
  #本地地址
  #localurl: "D:/springbootFile/upload/images/"

2.上传方法

 

  • 获取配置文件中配置的文件存储路径,将图片存储到本地或者服务器,页面通过映射获取。
      @Value("${file.uploadurl}")
    private String uploadPath;

 @PostMapping("/fileUpload")
    @ApiOperation(value = "上传下载图片")
    public JsonResult filesUpload(@RequestParam("filesName") MultipartFile file,
                                             @RequestParam("mmsi") String mmsi) throws IOException {

        JsonResult result = new JsonResult();
        //如果文件夹不存在,创建
        File fileP = new File(uploadPath);

        if (!fileP.isDirectory()) {
            //递归生成文件夹
            fileP.mkdirs();
        }
        String fileName = "";
        if(file.getOriginalFilename().endsWith(".jpg")){
            fileName =String.format("%s.jpg",System.currentTimeMillis());
        }else if(file.getOriginalFilename().endsWith(".png")){
            fileName =String.format("%s.jpg",System.currentTimeMillis());
        }else if(file.getOriginalFilename().endsWith(".jpeg")){
            fileName =String.format("%s.jpeg",System.currentTimeMillis());
        }else if(file.getOriginalFilename().endsWith(".bmp")){
            fileName =String.format("%s.bmp",System.currentTimeMillis());
        }else{
            result.setSuccess(false);
            result.setCode("0");
            result.setMessage("图片格式不正确!,使用.jpg/.png/.bpm/.jpeg后缀的图片");
            return result;
        }
        file.transferTo(new File(fileP,fileName));
        //数据库存入地址
        cxShipDetailService.insertShipPic(mmsi,uploadPath+fileName,fileName);
        result.setSuccess(true);
        result.setCode("1");
        result.setMessage("上传图片成功!");
        return result;
    }

上传功能就到此结束了。那么肯定会问,上传了怎么获取图片呢?很简单,通过地址映射就可以获取了。

3.配置类

 

  • 配置映射路径,例如:页面请求的图片路径为(默认到static目录下):images/111.jpg,static目录下没有该目录文件,将通过映射的imges到本地或者服务器的存储中获取。
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 FileConfig   implements WebMvcConfigurer {

    @Value("${file.uploadurl}")
    private String  fileUrl;

    public void addResourceHandlers(ResourceHandlerRegistry register){
        register.addResourceHandler("/images/**").addResourceLocations("file:"+fileUrl);
    }
}

方式二:除了配置类还有另一种方式,那就是直接在配置文件配置spring的资源文件地址:

spring:
  mvc: 
    static-path-pattern: /image/**
  resources:
    #本地地址
    static-locations: file:D://test/
    #linux服务器地址
   #static-locations: file:/u01/upload/images/

但是通过方式二有弊端,如果配置了swagger你会发现不能打开swagger了,是因为默认资源位置已被映射,无法找到, 所以需要通过配置类指定资源位置


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 WebMvcConfig implements WebMvcConfigurer  {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html")
                .addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**")
                .addResourceLocations("classpath:/META-INF/resources/webjars/");

    }

}

建议直接使用第一种方式!

效果:这里的imags对应配置类里面的获取地址。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值