程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现?

开发过程中遇到javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现的问题如何解决?下面主要结合日常开发的经验,给出你关于javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现的解决方法建议,希望对你解决javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现有所启发或帮助;

最后,我们发现了问题

我们在pom.xml中有一个依赖项,指向框架wiremock

     <dependency>
        <groupID>com.github.tomakehurst</groupID>
        <artifactID>wiremock</artifactID>
        <version>1.43</version>
        <exclusions>
             <exclusion>
              <groupID>org.mortbay.jetty</groupID>
              <artifactID>servlet-API</artifactID>
            </exclusion>
         </exclusions> 
    </dependency>

此框架在jar中包含一个/ keystore文件,该文件会产生此问题。当我们从pom中删除此依赖项时,一切正常。

解决方法

我的应用程序中有代码,尝试使用具有指定证书的httpS连接到外部主机。

我的代码如下所示:

    //Load Two Keystores
    KeyStore keystore = KeyStore.geTinstance("pkcs12","SunJSSE");
    InputStream keystoreInput = new FileInputStream(cerPath);
    keystore.load(keystoreInput,passwd.toCharArray());
    System.out.println("Keystore has " + keystore.size() + " keys");

    // load the truststore,leave it null to rely on cacerts diStributed with the JVM
    KeyStore truststore = KeyStore.geTinstance("pkcs12","SunJSSE");
    InputStream truststoreInput = new FileInputStream(cerPath);
    truststore.load(truststoreInput,passwd.toCharArray());
    System.out.println("Truststore has " + truststore.size() + " keys");

    //ssl context
    SSLContext sslcontext = SSLContext.geTinstance("TLS");
    sslcontext.init(null,null,null);
    SSLSocketFactory sf = new SSLSocketFactory(keystore,passwd);
    scheR_286_11845@e https = new scheR_286_11845@e("https",443,sf);

    scheR_286_11845@eRegistry scheR_286_11845@eRegistry = new scheR_286_11845@eRegistry();
    scheR_286_11845@eRegistry.register(https);
    ...
    client = new DefaulthttpClient(new PoolingClientConnectionManager(scheR_286_11845@eRegistry));
    ...
    httpResponse httpResponse = client.execute( targetHost,httpR_286_11845@ethod);

变量cerPath包含用于建立连接的证书(xxxx.pfx)的路径。

在独立的应用程序中,这可以完美地工作,但是在我的spring-boot应用程序中,相同的代码将引发以下异常:

javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No X509TrustManager implementation available

我已经在普通的Spring应用程序中测试了此代码,并且它也可以工作。

普通的SSL属性()也不起作用。

大佬总结

以上是大佬教程为你收集整理的javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现全部内容,希望文章能够帮你解决javax.net.ssl.SSLHandshakeException:java.security.cert.CertificateException:没有可用的X509TrustManager实现所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。