HttpURLConnection绕过HTTPS的SSL验证

(这个jdk环境需要是1.8,以上)。

直接在类里面加一个static代码块

 1 static {
 2         try {
 3             trustAllHttpsCertificates();
 4             HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
 5                 public boolean verify(String urlHostName, SSLSession session) {
 6                     return true;
 7                 }
 8             });
 9         } catch (Exception e) {
10         }
11     }

  在调用如下方法:

 1 private static void trustAllHttpsCertificates() throws NoSuchAlgorithmException, KeyManagementException {
 2         TrustManager[] trustAllCerts = new TrustManager[1];
 3         trustAllCerts[0] = new TrustAllManager();
 4         SSLContext sc = SSLContext.getInstance("SSL");
 5         sc.init(null, trustAllCerts, null);
 6         HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
 7     }
 8 
 9     private static class TrustAllManager implements X509TrustManager {
10         public X509Certificate[] getAcceptedIssuers() {
11             return null;
12         }
13 
14         public void checkServerTrusted(X509Certificate[] certs, String authType) throws CertificateException {
15         }
16 
17         public void checkClientTrusted(X509Certificate[] certs, String authType) throws CertificateException {
18         }
19     }

这样就应该没有问题了。

posted @ 2018-07-30 17:47  缘木与鱼  阅读(4953)  评论(1编辑  收藏  举报