Minio使用https自签证书

自签证书参考:window和ubuntu自签证书_windows 自签证书-CSDN博客

java 复制代码
// certFilePath: 直接放在 resources 目录下 或者可以自定实现读取逻辑  

// 读取的是  .crt 证书文件

public static OkHttpClient createTrustingOkHttpClient(String certFilePath) throws Exception {
        // 1. 加载证书
        CertificateFactory cf = CertificateFactory.getInstance("X.509");
        InputStream certInput = SSLUtil.class.getClassLoader().getResourceAsStream(certFilePath);
        if (certInput == null || certInput.available() == 0) {
            throw new RuntimeException("证书读取失败");
        }
        X509Certificate ca = (X509Certificate) cf.generateCertificate(certInput);

        // 2. 创建KeyStore并导入证书
        KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
        keyStore.load(null, null);
        keyStore.setCertificateEntry("ca", ca);

        // 3. 创建TrustManager信任我们的KeyStore
        TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
        tmf.init(keyStore);

        // 4. 创建SSLContext
        SSLContext sslContext = SSLContext.getInstance("TLS");
        sslContext.init(null, tmf.getTrustManagers(), null);

        // 5. 创建OkHttpClient
        return new OkHttpClient.Builder()
                .sslSocketFactory(sslContext.getSocketFactory(), (X509TrustManager) tmf.getTrustManagers()[0])
                .hostnameVerifier((hostname, session) -> true) // 可选:禁用主机名验证
                .build();
    }




public static void main(String[] args) throws Exception {
        // 构建 OkHttpClient
        OkHttpClient insecureClient = createTrustingOkHttpClient("test_10.crt");

        MinioClient client = MinioClient.builder()
                .endpoint("https://192.168.0.101:9000")
                .credentials("abc-bucket", "123456")
                .region("us-east-1")
                .httpClient(insecureClient)
                .build();

        List<Bucket> buckets = client.listBuckets();
        System.out.println(buckets);
    }
相关推荐
温柔的小猪竹5 小时前
面向对象的六大原则
java
洛小豆5 小时前
孤儿资源治理:如何优雅处理“上传了但未提交”的冗余文件?
java·后端·面试
小小bugbug5 小时前
close关闭 tcp套接字和 shutdown关闭 tcp套接字的区别
网络·网络协议·tcp/ip
a努力。5 小时前
中国电网Java面试被问:分布式缓存的缓存穿透解决方案
java·开发语言·分布式·缓存·postgresql·面试·linq
草莓熊Lotso6 小时前
脉脉独家【AI创作者xAMA】| 开启智能创作新时代
android·java·开发语言·c++·人工智能·脉脉
爱吃山竹的大肚肚6 小时前
Kafka中auto-offset-reset各个选项的作用
java·spring boot·spring·spring cloud
只想要搞钱6 小时前
java 常用业务方法-记录
java
CodeAmaz6 小时前
HashMap 面试全攻略
java·hashmap
moxiaoran57536 小时前
Java设计模式的运用
java·开发语言·设计模式
西柚补习生6 小时前
ESP8266远端固定UDP传输
网络·网络协议·udp