整合minio时出现的错误

Action:Correct the classpath of your application so that it contains compatible versions of the classes io.minio.S3Base and okhttp3.RequestBody

这个错误是我在整合minio时报的错,说实话遇到这个错误我还是很头大的,因为之前在springboot项目中整合过一次minio,当时报的错误跟这个差不多,都是okhttp版本依赖问题,之前是因为,我的minio依赖里面自带的okhttp包的版本过低,需要将minio包中的okhttp包剔除,自己手动引进一个更高版本的okhttp包。

<!--maven引入minio排除okhttp依赖并添加高版本的okhttp依赖-->
        <dependency>
            <groupId>io.minio</groupId>
            <artifactId>minio</artifactId>
            <version>8.5.2</version>
            <exclusions>
                <exclusion>
                    <groupId>com.squareup.okhttp3</groupId>
                    <artifactId>okhttp</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>4.9.0</version>
        </dependency>

就像上述代码一样,这样就可以解决okhttp版本的问题。但是这次报的错误跟上次几乎一样,追根揭底也是okhttp包版本问题,这次是版本冲突问题。

这就是这个错误奇怪的地方,发现是版本冲突后,我查看了这个项目的版本依赖,但是没有发现有关okhttp的版本冲突存在。

又从头看了一下报错信息,发现了一个奇怪的地方。

The called method's class, okhttp3.RequestBody, is available from the following locations:

    jar:file:/D:/repository/com/squareup/okhttp3/okhttp/3.14.9/okhttp-3.14.9.jar!/okhttp3/RequestBody.class

The called method's class hierarchy was loaded from the following locations:

    okhttp3.RequestBody: file:/D:/repository/com/squareup/okhttp3/okhttp/3.14.9/okhttp-3.14.9.jar

它不知道从哪给我加载了一个3.14.9版本的okhttp,而我引入的依赖是4.9.0的版本,然后我又看了一下我项目引入的依赖库,确实找到了两个版本的okhttp。

okhttp版本冲突

然后我就开始找这个3.14.9版本的okhttp是从哪里引进来的,自己折腾了一大晌还是没有找到,后来就放弃了,等到第二天再来看这个错误的时候,在这个okhttp依赖旁边发现了这个

okhttpmaven依赖

本来也是没发现什么异常,就是实在没法了点了一下,就进到了这里

okhttp依赖版本控制

嘿,搁这找到了,往上翻,找到他的版本号

okhttp版本号

好家伙,原来搁这了,那现在就是想办法把这个版本号给覆盖掉就行了,在我的这个项目的父工程里加入这个okhttp的版本号,在这个项目里引用这个版本号,重新启动,问题解决。

版本号指定

<!--maven引入minio排除okhttp依赖并添加高版本的okhttp依赖-->
        <dependency>
            <groupId>io.minio</groupId>
            <artifactId>minio</artifactId>
            <version>8.5.2</version>
            <exclusions>
                <exclusion>
                    <groupId>com.squareup.okhttp3</groupId>
                    <artifactId>okhttp</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>${okhttp3.version}</version>
        </dependency>
### Java 整合 MinIO 示例教程及依赖配置 #### 1. Maven 依赖配置 为了在 Java 项目中使用 MinIO 对象存储服务,首先需要在项目的 `pom.xml` 文件中添加 MinIO 的官方客户端库作为依赖。 ```xml <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifactId> <version>8.5.7</version> <!-- 版本号需根据实际需求调整 --> </dependency> ``` 上述代码片段展示了如何通过 Maven 配置 MinIO 客户端的依赖项[^1]。 --- #### 2. Spring Boot 中的 MinIO 集成示例 如果是在基于 Spring Boot 的项目中集成 MinIO,则可以通过以下方式实现: ##### (a) 创建 MinIO Client Bean 定义一个用于管理 MinIO 连接的 Bean,以便在整个应用中共享该实例。 ```java import io.minio.MinioClient; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MinioConfig { @Bean public MinioClient minioClient() { return MinioClient.builder() .endpoint("http://localhost:9000") // 替换为实际的 MinIO 地址 .credentials("your-access-key", "your-secret-key") // 设置访问密钥和秘密密钥 .build(); } } ``` 此部分代码实现了 MinIO 客户端的初始化,并将其注册到 Spring 应用上下文中[^2]。 --- ##### (b) 使用 MinIO API 存储文件 下面是一个简单的示例,展示如何上传文件至 MinIO 并设置元数据。 ```java import io.minio.PutObjectArgs; import io.minio.MinioClient; import java.io.File; @Service public class FileService { private final MinioClient minioClient; public FileService(MinioClient minioClient) { this.minioClient = minioClient; } public void uploadFile(String bucketName, String objectName, File file) throws Exception { minioClient.putObject( PutObjectArgs.builder() .bucket(bucketName) .object(objectName) .filename(file.getAbsolutePath()) .contentType("application/octet-stream") .build()); } } ``` 这段代码演示了如何利用 MinIO 提供的 `putObject` 方法完成文件上传功能[^4]。 --- #### 3. Optional 类的作用说明 当处理返回值可能存在空的情况,可以借助 Java 8 引入的 `Optional` 来避免潜在的空指针异常。例如,在调用某些 MinIO 接口并验证其结果存在性,推荐采用如下写法: ```java import io.minio.GetObjectResponse; import java.util.Optional; public Optional<byte[]> downloadFileContent(String bucketName, String fileName) { try (GetObjectResponse response = minioClient.getObject(GetObjectArgs.builder().bucket(bucketName).object(fileName).build())) { byte[] content = response.readAllBytes(); return Optional.ofNullable(content); } catch (Exception e) { return Optional.empty(); // 如果发生错误则返回空值 } } ``` 这里通过封装下载逻辑于 `Optional` 中,有效提升了程序健壮性和可读性[^3]。 --- #### 总结 以上内容涵盖了从环境准备、Maven 依赖引入到具体业务场景下的编码实践等多个方面,旨在帮助开发者快速掌握 JavaMinIO 结合使用的技巧。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值