java调用https接口报错详解编程语言

本文章主要介绍了java调用https接口报错,具有不错的的参考价值,希望对您有所帮助,如解说有误或未考虑完全的地方,请您留言指出,谢谢!

调用第三方https接口,在本地测试没问题,将项目提交到测试环境怎么都掉不通,报如下错误:

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(Alerts.java:192) ~[na:1.7.0_71] 
    at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1884) ~[na:1.7.0_71] 
    at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:276) ~[na:1.7.0_71] 
    at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:270) ~[na:1.7.0_71] 
    at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1439) ~[na:1.7.0_71] 
    at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:209) ~[na:1.7.0_71] 
    at sun.security.ssl.Handshaker.processLoop(Handshaker.java:878) ~[na:1.7.0_71] 
    at sun.security.ssl.Handshaker.process_record(Handshaker.java:814) ~[na:1.7.0_71] 
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1016) ~[na:1.7.0_71] 
    at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1312) ~[na:1.7.0_71] 
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1339) ~[na:1.7.0_71] 
    at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1323) ~[na:1.7.0_71]

查了下大概就是说没证书,本地是在chrome浏览器上测试的,测试过程中一直没提示说要安装什么证书,也看了下本地的证书,……东西太多,一下子找不出到底本地在不知道的情况下安装了哪个证书,网上查了很多资料,有说在服务器上安装证书的,有说改代码的,最后解决的办法是创建CloseableHttpClient用了以下代码,https接口成功调用:

public static CloseableHttpClient createSSLClientDefault(){ 
        try { 
            SSLContext sslContext = new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() { 
                //信任所有 
                public boolean isTrusted(X509Certificate[] chain, String authType) throws CertificateException { 
                    return true; 
                } 
            }).build(); 
            SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslContext); 
            return HttpClients.custom().setSSLSocketFactory(sslsf).build(); 
        } catch (KeyManagementException e) { 
            e.printStackTrace(); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } catch (KeyStoreException e) { 
            e.printStackTrace(); 
        } 
        return  HttpClients.createDefault(); 
    }

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/228212.html

(1)
上一篇 2022年1月11日
下一篇 2022年1月11日

相关推荐

发表回复

登录后才能评论