SpringBoot项目文件上传适配本地存储、MinIO存储、FastDfs存储

        文件上传是每个项目中必不可少的功能,随着开发的项目越来越多,我们可以把文件上传进行多种适配,满足不同场合、不同环境的需要,闲话少叙,奉上实现方法。

        本地文件适配:

        1、配置文件

# 本地文件上传    
file:
    # 访问地址
    domain: http://127.0.0.1:9090
	# 本地存放的路径地址
    path: D:/localFile/uploadPath
	# 映射地址
    prefix: /statics

        2、增加路径映射,继承WebMvcConfigurer,重写addResourceHandlers,在registry里面配置访问路径和映射到的服务器本地路径。

@Override
    public void addResourceHandlers(ResourceHandlerRegistry registry)
    {
        /** 本地文件上传路径 */
        registry.addResourceHandler(localFilePrefix + "/**")
                .addResourceLocations("file:" + localFilePath + File.separator);
    }

        3、上传文件,在LocalSysFileServiceImpl中重写uploadFile方法。

@Override
    public String uploadFile(MultipartFile file) throws Exception
    {
        String name = FileUploadUtils.upload(localFilePath, file);
        String url = domain + localFilePrefix + name;
        return url;
    }

        MinIO存储:

        1、配置文件

# Minio配置
minio:
  url: http://127.0.0.1:9000
  # 账号
  accessKey: minioadmin
  # 密码
  secretKey: minioadmin
  # MinIO桶名字
  bucketName: myBucket

        2、上传文件,在MinioSysFileServiceImpl中重写uploadFile方法。

@Override
    public String uploadFile(MultipartFile file) throws Exception
    {
        String fileName = FileUploadUtils.extractFilename(file);
        PutObjectArgs args = PutObjectArgs.builder()
                .bucket(minioConfig.getBucketName())
                .object(fileName)
                .stream(file.getInputStream(), file.getSize(), -1)
                .contentType(file.getContentType())
                .build();
        client.putObject(args);
        return minioConfig.getUrl() + "/" + minioConfig.getBucketName() + "/" + fileName;
    }

        FastDfs存储:

        1、配置文件

# FastDFS配置
fdfs:
  domain: http://8.129.231.12
  soTimeout: 3000
  connectTimeout: 2000
  trackerList: 8.129.231.12:22122

        2、上传文件,在FastDfsSysFileServiceImpl中重写uploadFile方法。

@Override
    public String uploadFile(MultipartFile file) throws Exception
    {
        StorePath storePath = storageClient.uploadFile(file.getInputStream(), file.getSize(),
                FilenameUtils.getExtension(file.getOriginalFilename()), null);
        return domain + "/" + storePath.getFullPath();
    }

        最后通过把注解@Primary标注在对应的Service类上来标识采用哪种方式存储文件。源码后续提供。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在使用@Async异步处理上传文件时,可能会遇到文件不存在的异常。这是由于异步处理会在上传文件完成之前就返回,导致文件还未上传完成,异步处理就已经开始了。 解决方法是使用CompletableFuture类来等待文件上传完成后再处理,示例代码如下: ``` @Service public class FileService { @Autowired private MinioClient minioClient; @Async public CompletableFuture<String> uploadFile(MultipartFile file, String bucketName, String objectName) { try { minioClient.putObject(bucketName, objectName, file.getInputStream(), file.getContentType()); return CompletableFuture.completedFuture("File uploaded successfully"); } catch (Exception e) { return CompletableFuture.failedFuture(e); } } public String handleFileUpload(MultipartFile file) throws Exception { String bucketName = "my-bucket"; String objectName = file.getOriginalFilename(); CompletableFuture<String> future = uploadFile(file, bucketName, objectName); future.thenAccept(result -> { // 处理上传文件成功的逻辑 }).exceptionally(ex -> { // 处理上传文件失败的逻辑 return null; }).join(); return "File upload started"; } } ``` 在handleFileUpload方法中,先调用uploadFile方法上传文件,然后使用CompletableFuture类等待文件上传完成后再进行处理。在future.thenAccept方法中处理上传文件成功的逻辑,在future.exceptionally方法中处理上传文件失败的逻辑。最后调用join方法等待异步处理完成。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chenjp111111

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值