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