如何使用Spring Boot和MinIO实现文件上传、读取、下载和删除的功能?

简介: 如何使用Spring Boot和MinIO实现文件上传、读取、下载和删除的功能?

引言

在现代Web应用程序开发中,文件的上传、读取、下载和删除是非常常见的功能。Spring Boot 是一个流行的Java框架,而MinIO则是一个高性能的对象存储服务。本文将详细介绍如何使用Spring Boot和MinIO实现文件上传、读取、下载和删除的功能。

准备工作

在开始之前,需要进行一些准备工作:

  1. 安装Java JDK并配置好环境变量。
  2. 安装Maven构建工具。
  3. 创建一个新的Spring Boot项目。

步骤一:添加所需依赖

首先,在项目的pom.xml文件中添加以下依赖:

<dependencies>
    <!-- Spring Boot Web -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- MinIO Java SDK -->
    <dependency>
        <groupId>io.minio</groupId>
        <artifactId>minio</artifactId>
        <version>8.4.0</version>
    </dependency>
</dependencies>

这里我们添加了Spring Boot Web依赖以及MinIO Java SDK依赖。

步骤二:配置MinIO连接信息

在application.properties(或application.yml)文件中添加MinIO连接信息:

# MinIO连接信息
minio.url=http://localhost:9000
minio.accessKey=minio_access_key
minio.secretKey=minio_secret_key

这里需要将minio.urlminio.accessKeyminio.secretKey替换为你实际使用的MinIO连接信息。

步骤三:编写文件上传接口

创建一个新的REST Controller类,用于处理文件上传:

@RestController
public class FileController {
   
   

    @Value("${minio.url}")
    private String minioUrl;

    @Value("${minio.accessKey}")
    private String minioAccessKey;

    @Value("${minio.secretKey}")
    private String minioSecretKey;

    // 文件上传接口
    @PostMapping("/upload")
    public String uploadFile(@RequestParam("file") MultipartFile file) {
   
   
        try {
   
   
            // 创建MinIO客户端
            MinioClient minioClient = MinioClient.builder()
                    .endpoint(minioUrl)
                    .credentials(minioAccessKey, minioSecretKey)
                    .build();

            // 生成随机文件名
            String filename = UUID.randomUUID().toString() + "-" + file.getOriginalFilename();

            // 使用putObject方法上传文件
            minioClient.putObject(PutObjectArgs.builder()
                    .bucket("my-bucket") // 替换为你实际的存储桶名称
                    .object(filename)
                    .stream(file.getInputStream(), file.getSize(), -1)
                    .contentType(file.getContentType())
                    .build());

            return "文件上传成功";
        } catch (Exception e) {
   
   
            e.printStackTrace();
            return "文件上传失败:" + e.getMessage();
        }
    }
}

这个接口使用@PostMapping注解定义了一个文件上传的POST请求接口。在方法内部,我们首先获取MinIO连接信息,并创建MinioClient实例。然后,生成一个随机文件名,使用putObject方法将文件上传到指定的存储桶中。

请注意,这里的存储桶名称需要根据你实际的需求进行替换。

步骤四:编写文件读取接口

继续在FileController类中添加一个文件读取的接口:

@GetMapping("/read/{filename}")
public ResponseEntity<InputStreamResource> readFile(@PathVariable String filename) {
   
   
    try {
   
   
        // 创建MinIO客户端
        MinioClient minioClient = MinioClient.builder()
                .endpoint(minioUrl)
                .credentials(minioAccessKey, minioSecretKey)
                .build();

        // 获取文件流
        GetObjectResponse objectResponse = minioClient.getObject(GetObjectArgs.builder()
                .bucket("my-bucket") // 替换为你实际的存储桶名称
                .object(filename)
                .build());

        InputStream inputStream = objectResponse;

        // 设置响应头
        HttpHeaders headers = new HttpHeaders();
        headers.add(HttpHeaders.CONTENT_TYPE, objectResponse.contentType());

        return ResponseEntity.ok()
                .headers(headers)
                .body(new InputStreamResource(inputStream));
    } catch (Exception e) {
   
   
        e.printStackTrace();
        return ResponseEntity.notFound().build();
    }
}

这个接口使用@GetMapping注解定义了一个文件读取的GET请求接口。在方法内部,我们首先获取MinIO连接信息,并创建MinioClient实例。然后,使用getObject方法获取文件流,并将其封装为InputStreamResource对象。

步骤五:编写文件下载接口

在FileController类中继续添加一个文件下载的接口:

@GetMapping("/download/{filename}")
public ResponseEntity<InputStreamResource> downloadFile(@PathVariable String filename) {
   
   
    try {
   
   
        // 创建MinIO客户端
        MinioClient minioClient = MinioClient.builder()
                .endpoint(minioUrl)
                .credentials(minioAccessKey, minioSecretKey)
                .build();

        // 获取文件流
        GetObjectResponse objectResponse = minioClient.getObject(GetObjectArgs.builder()
                .bucket("my-bucket") // 替换为你实际的存储桶名称
                .object(filename)
                .build());

        InputStream inputStream = objectResponse;

        // 设置响应头
        HttpHeaders headers = new HttpHeaders();
        headers.add(HttpHeaders.CONTENT_TYPE, objectResponse.contentType());
        headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + filename + "\"");

        return ResponseEntity.ok()
                .headers(headers)
                .body(new InputStreamResource(inputStream));
    } catch (Exception e) {
   
   
        e.printStackTrace();
        return ResponseEntity.notFound().build();
    }
}

这个接口也使用@GetMapping注解定义了一个文件下载的GET请求接口。与文件读取接口类似,我们首先获取MinIO连接信息,并创建MinioClient实例。然后,使用getObject方法获取文件流,并将其封装为InputStreamResource对象。

不同之处在于,我们设置了Content-Disposition响应头,指定文件的下载方式。

步骤六:编写文件删除接口

最后,在FileController类中添加文件删除的接口:

@DeleteMapping("/delete/{filename}")
public String deleteFile(@PathVariable String filename) {
   
   
    try {
   
   
        // 创建MinIO客户端
        MinioClient minioClient = MinioClient.builder()
                .endpoint(minioUrl)
                .credentials(minioAccessKey, minioSecretKey)
                .build();

        // 删除文件
        minioClient.removeObject(RemoveObjectArgs.builder()
                .bucket("my-bucket") // 替换为你实际的存储桶名称
                .object(filename)
                .build());

        return "文件删除成功";
    } catch (Exception e) {
   
   
        e.printStackTrace();
        return "文件删除失败:" + e.getMessage();
    }
}

这个接口使用@DeleteMapping注解定义了一个文件删除的DELETE请求接口。在方法内部,我们首先获取MinIO连接信息,并创建MinioClient实例。然后,使用removeObject方法从指定的存储桶中删除文件。

测试

完成以上步骤后,你可以启动Spring Boot应用程序,并使用任何HTTP客户端(如Postman)来测试文件上传、读取、下载和删除的功能。

例如,使用POST方法请求http://localhost:8080/upload接口来上传文件,使用GET方法请求http://localhost:8080/read/{filename}接口来读取文件,使用GET方法请求http://localhost:8080/download/{filename}接口来下载文件,使用DELETE方法请求http://localhost:8080/delete/{filename}接口来删除文件。

请记得根据实际情况替换URL中的{filename}和存储桶名称。

结论

通过使用Spring Boot和MinIO,我们可以方便地实现文件上传、读取、下载和删除的功能。在实际应用中,你可能还需要添加更多的功能,如文件列表、权限控制等。希望本文对你有所帮助,祝你在使用Spring Boot和MinIO开发文件管理功能时取得成功!

目录
相关文章
|
1月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
340 2
|
6月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
237 32
|
6月前
|
安全 Java API
Spring Boot 功能模块全解析:构建现代Java应用的技术图谱
Spring Boot不是一个单一的工具,而是一个由众多功能模块组成的生态系统。这些模块可以根据应用需求灵活组合,构建从简单的REST API到复杂的微服务系统,再到现代的AI驱动应用。
|
5月前
|
监控 安全 Java
Java 开发中基于 Spring Boot 3.2 框架集成 MQTT 5.0 协议实现消息推送与订阅功能的技术方案解析
本文介绍基于Spring Boot 3.2集成MQTT 5.0的消息推送与订阅技术方案,涵盖核心技术栈选型(Spring Boot、Eclipse Paho、HiveMQ)、项目搭建与配置、消息发布与订阅服务实现,以及在智能家居控制系统中的应用实例。同时,详细探讨了安全增强(TLS/SSL)、性能优化(异步处理与背压控制)、测试监控及生产环境部署方案,为构建高可用、高性能的消息通信系统提供全面指导。附资源下载链接:[https://pan.quark.cn/s/14fcf913bae6](https://pan.quark.cn/s/14fcf913bae6)。
909 0
|
8月前
|
存储 Java 文件存储
🗄️Spring Boot 3 整合 MinIO 实现分布式文件存储
本文介绍了如何基于Spring Boot 3和MinIO实现分布式文件存储。随着应用规模扩大,传统的单机文件存储方案难以应对大规模数据和高并发访问,分布式文件存储系统成为更好的选择。文章详细讲解了MinIO的安装、配置及与Spring Boot的整合步骤,包括Docker部署、MinIO控制台操作、Spring Boot项目中的依赖引入、配置类编写及工具类封装等内容。最后通过一个上传头像的接口示例展示了具体的开发和测试过程,强调了将API操作封装成通用工具类以提高代码复用性和可维护性的重要性。
1808 7
🗄️Spring Boot 3 整合 MinIO 实现分布式文件存储
|
6月前
|
存储 Java Linux
SpringBoot × MinIO 极速开发指南:对象存储服务高可用实战
生成临时访问URL接口和文件预览其实是同一个方法,只是文件预览内定了七天访问,而这个方法可以自行制定,单位是秒。方法,所以返回的是地址信息,但是可以通过dubug看到Bucket中的属性,确实是当前所有桶信息。配置类中奖MinIOClient客户端注入到Springboot中。MinIO集群的在Linux上的部署可以参考:​​​​​​​。Nginx代理MinIO集群可以参考:​​​​​​​。从Bucket源码可以看出,并没有实现。
665 0
|
7月前
|
SQL 前端开发 Java
深入理解 Spring Boot 项目中的分页与排序功能
本文深入讲解了在Spring Boot项目中实现分页与排序功能的完整流程。通过实际案例,从Service层接口设计到Mapper层SQL动态生成,再到Controller层参数传递及前端页面交互,逐一剖析每个环节的核心逻辑与实现细节。重点包括分页计算、排序参数校验、动态SQL处理以及前后端联动,确保数据展示高效且安全。适合希望掌握分页排序实现原理的开发者参考学习。
480 4
|
4月前
|
Java Spring 容器
SpringBoot自动配置的原理是什么?
Spring Boot自动配置核心在于@EnableAutoConfiguration注解,它通过@Import导入配置选择器,加载META-INF/spring.factories中定义的自动配置类。这些类根据@Conditional系列注解判断是否生效。但Spring Boot 3.0后已弃用spring.factories,改用新格式的.imports文件进行配置。
866 0
|
1月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
266 3