JAva呼び出しhttpsインタフェースエラー

7051 ワード

サードパーティ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();
    }