java无法验证证书_解决https证书验证不通过的问题

1、报错信息

java.security.cert.CertificateException: No name matching api.weibo.com found; nested exception is javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No name matching api.weibo.com found

原因:在调用api.weibo.com的时候,我们使用的是https的方式,正常情况下应该是使用api.weibo.com的证书,但由于某些原因,我们只能使用自己的证书,导致在验证证书的时候,就报了这个错误。

解决的办法:忽略服务端和客户端的证书校验即可。java 提供的相关的类。

2、具体实现方式

通过重写TrustManager的checkClientTrusted(检查客户端证书信任)和checkServerTrusted(检查服务端证书验证)。

以及HostnameVerifier的verify(校验)方法即可取消对证书的所有验证。

importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;import javax.net.ssl.*;importjava.io.IOException;importjava.net.URL;importjava.security.cert.CertificateException;importjava.security.cert.X509Certificate;public final classDisableSSLCertificateCheckUtil {private static final Logger LOGGER = LoggerFactory.getLogger(DisableSSLCertificateCheckUtil.class);/*** Prevent instantiation of utility class.*/

privateDisableSSLCertificateCheckUtil() {

}/*** Disable trust checks for SSL connections.*/

public static voiddisableChecks() {try{new URL("https://0.0.0.0/").getContent();

}catch(IOException e) {//This invocation will always fail, but it will register the//default SSL provider to the URL class.

}try{

SSLContext sslc;

sslc= SSLContext.getInstance("TLS");

TrustManager[] trustManagerArray= {newX509TrustManager() {

@Overridepublic void checkClientTrusted(X509Certificate[] chain, String authType) throwsCertificateException {

}

@Overridepublic void checkServerTrusted(X509Certificate[] chain, String authType) throwsCertificateException {

}

@OverridepublicX509Certificate[] getAcceptedIssuers() {return new X509Certificate[0];

}

}};

sslc.init(null, trustManagerArray, null);

HttpsURLConnection.setDefaultSSLSocketFactory(sslc.getSocketFactory());

HttpsURLConnection.setDefaultHostnameVerifier(newHostnameVerifier() {

@Overridepublic booleanverify(String s, SSLSession sslSession) {return true;

}

});

}catch(Exception e) {

LOGGER.error("error msg:{}", e);throw new IllegalArgumentException("证书校验异常!");

}

}

}

调用方式:

DisableSSLCertificateCheckUtil.disableChecks();

影响的范围:将会影响整个tomcat里面对证书的验证。即通过tomcat里面的其他项目虽然没有执行这一段代码但是也同样会忽略证书的验证。

影响的时间:执行这段代码之后的所有时间都生效。

致谢:感谢您的耐心阅读!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值