sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath

本文介绍了如何在遇到HTTPS请求中缺少安全证书认证的问题时,通过自定义创建SSLInsecureHttpClient解决,包括修改HTTPclient创建方式和使用自定义的SSL信任策略。适合内部调用场景的安全配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原因

https证书
请求为https
缺少安全证书认证

解决方式

若是内部调用,不担心安全问题则直接调整代码如下
httpclients的修改方式

// 修改HTTP client的创建方式
CloseableHttpClient httpClient = null;
// 创建Httpclient对象   actionUrl为请求全路径
 if (actionUrl.startsWith(HTTPS)) {
     // 创建一个SSL信任所有证书的httpClient对象
     httpClient = HttpClientUtil.getSSLInsecure();
 } else {
     httpClient = HttpClients.createDefault();
 }

getSSLInsecure为自定义方法 如下定义 放到同一类下即可

    public static CloseableHttpClient createSSLInsecureClient() {
        try {
            SSLConnectionSocketFactory sslcsf = new SSLConnectionSocketFactory(
                    SSLContexts.custom().loadTrustMaterial(null, new TrustSelfSignedStrategy()).build(),
                    NoopHostnameVerifier.INSTANCE);

            return HttpClients.custom().setSSLSocketFactory(sslcsf).build();
        } catch (Exception e) {
        	// 日志不需要可以换为 其他 如e.printStackTrace();
            logger.error("createSSLInsecureClient方法出现异常", e);
        }

        return HttpClients.createDefault();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值