Java语言使用websercive服务器绕过https安全证书访问
主要就是调用两个方法:
trustAllHttpsCertificates();
HttpsURLConnection.setDefaultHostnameVerifier(hv);
将这两个方法放到开始连接url的前面就可以。
具体实现如下面:直接复制就可以 /**
publicboolean isClientTrusted(
java.security.cert.X509Certificate[] certs) {
publicboolean isServerTrusted( }
java.security.cert.X509Certificate[] certs) { returntrue;
staticclass miTM implements javax.net.ssl.TrustManager,
}
javax.net.ssl.X509TrustManager { returnnull;
public java.security.cert.X509Certificate[] getAcceptedIssuers() { privatestaticvoidtrustAllHttpsCertificates() throws Exception { }
javax.net.ssl.TrustManager[] trustAllCerts = new javax.net.ssl.TrustManager[1]; javax.net.ssl.TrustManager tm = new miTM(); trustAllCerts[0] = tm;
javax.net.ssl.SSLContext sc = javax.net.ssl.SSLContext
.getInstance(\);
sc.init(null, trustAllCerts, null);
javax.net.ssl.HttpsURLConnection.setDefaultSSLSocketFactory(sc
.getSocketFactory());
* 跳过https访问webserivce的方法 start */
HostnameVerifier hv = new HostnameVerifier() { };
publicboolean verify(String urlHostName, SSLSession session) { }
System.out.println(\ + urlHostName + \
+ session.getPeerHost());
returntrue;
}
}
returntrue;
publicvoid checkServerTrusted( }
publicvoid checkClientTrusted( }
java.security.cert.X509Certificate[] certs, String authType) throws java.security.cert.CertificateException {
java.security.cert.X509Certificate[] certs, String authType) throws java.security.cert.CertificateException {
return;
return;
/**
* 跳过https访问webserivce的方法 end */
视图