minioJava客户端调https接口报:xxx PKIX path building failed

minioJava客户端调https接口报:xxx PKIX path building failed

开启minio的https访问后,下载访问图片用http是可以的,但是上传的时候报:

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
at sun.security.ssl.Alerts.getSSLException(Unknown Source)
at sun.security.ssl.SSLSocketImpl.fatal(Unknown Source)
at sun.security.ssl.Handshaker.fatalSE(Unknown Source)

  网上有一种解决方案是将服务端的ssl证书导入到jdk的证书信任列表中,这种方式试过了,不太可行。感兴趣的同学可自行百度~
  下来介绍第二种方式,那就是跟踪minio客户端连接代码的源码,看看是否有对应的方法能绕过ssl验证。
new new MinioClient(xxx);有很多的重载方法,其中有一个可以传入OkHttpClient,通过这个参数我们就可以绕过ssl的验证。具体实现如下所示:

@Bean
public MinioClient getMinioClient() throws InvalidEndpointException, InvalidPortException, KeyManagementException {
    OkHttpClient okHttpClient = getUnsafeOkHttpClient();
    return new MinioClient(endpoint, port, accessKey, secretKey,null, secure, okHttpClient);
}

public static OkHttpClient getUnsafeOkHttpClient() throws KeyManagementException {
    try {
        final TrustManager[] trustAllCerts = new TrustManager[]{
                new X509TrustManager() {
                    @Override
                    public void checkClientTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

                    }

                    @Override
                    public void checkServerTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

                    }

                    @Override
                    public X509Certificate[] getAcceptedIssuers() {
                        return new X509Certificate[]{};
                    }
                }
        };


        final SSLContext sslContext = SSLContext.getInstance("SSL");
        sslContext.init(null, trustAllCerts, new SecureRandom());
        final SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();
        OkHttpClient.Builder builder = new OkHttpClient.Builder();
		//注意这里,OkHttpClient再jdk1.8.0_271版本之后废弃了这个方法 clientBuilder.sslSocketFactory(SSLSocketFactory),故采用如下方式
       	builder.sslSocketFactory(sslSocketFactory,getX509TrustManager());


        builder.hostnameVerifier(new HostnameVerifier() {
            @Override
            public boolean verify(String s, SSLSession sslSession) {
                return true;
            }
        });
        return builder.build();

    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    return null;
}

public static X509TrustManager getX509TrustManager() {
    X509TrustManager trustManager = null;
    try {
        TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
        trustManagerFactory.init((KeyStore) null);
        TrustManager[] trustManagers = trustManagerFactory.getTrustManagers();
        if (trustManagers.length != 1 || !(trustManagers[0] instanceof X509TrustManager)) {
            throw new IllegalStateException("Unexpected default trust managers:" + Arrays.toString(trustManagers));
        }
        trustManager = (X509TrustManager) trustManagers[0];
    } catch (Exception e) {
        e.printStackTrace();
    }

    return trustManager;
}
以下是 Python 代码下载 Minio 图片并捕获异常使程序继续运行的示例: ```python import os import requests from urllib.parse import urlparse from minio import Minio from minio.error import ResponseError # 初始化 Minio 客户端 minio_client = Minio('minio.example.com', access_key='ACCESS_KEY', secret_key='SECRET_KEY', secure=True) # 下载图片并捕获异常 def download_image(bucket_name, object_name, file_path): try: # 获取图片的URL presigned_url = minio_client.presigned_get_object(bucket_name, object_name) # 解析URL获取图片的文件名 file_name = os.path.basename(urlparse(presigned_url).path) # 发起HTTP求下载图片 response = requests.get(presigned_url, stream=True, timeout=10) # 如果HTTP状态码不是200,则抛出异常 response.raise_for_status() # 将图片保存到本地文件 with open(os.path.join(file_path, file_name), 'wb') as f: for chunk in response.iter_content(1024): f.write(chunk) except (ResponseError, requests.exceptions.RequestException) as e: print(f"下载图片失败:{e}") # 在这里添加异常处理代码,例如打印错误日志或者发送邮件通知管理员 # 用 download_image 函数下载图片 download_image('my-bucket', 'image.jpg', '/path/to/save/image') ``` 在上面的代码中,我们通过 try-except 语句来捕获 Minio 客户端和 HTTP 求可能会抛出的异常,并在 except 分支中添加相应的异常处理代码。如果在下载图片的过程中出现异常,程序会继续执行,而不会因为异常而中断。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Zerooooooooooooooooo

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

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

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

打赏作者

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

抵扣说明:

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

余额充值