| | |
| | | |
| | | import okhttp3.*; |
| | | |
| | | import javax.net.ssl.*; |
| | | import java.io.IOException; |
| | | import java.security.KeyStore; |
| | | import java.security.SecureRandom; |
| | | import java.security.cert.X509Certificate; |
| | | import java.util.Arrays; |
| | | import java.util.Map; |
| | | import java.util.Optional; |
| | | import java.util.concurrent.TimeUnit; |
| | |
| | | * @return the HttpHandler instance |
| | | */ |
| | | private OkHttpClient getClient(Integer timeout, TimeUnit timeUnit){ |
| | | return new OkHttpClient |
| | | .Builder() |
| | | .connectTimeout(timeout, timeUnit) |
| | | .readTimeout(timeout, timeUnit) |
| | | .build(); |
| | | // return new OkHttpClient |
| | | // .Builder() |
| | | // .sslSocketFactory(getSSLSocketFactory(),getX509TrustManager()) |
| | | // .hostnameVerifier(getHostnameVerifier()) |
| | | // .connectTimeout(timeout, timeUnit) |
| | | // .readTimeout(timeout, timeUnit) |
| | | // .build(); |
| | | return OKHttpUtil.getInstance(); |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | |
| | | } |
| | | /** |
| | | * description 忽略https证书验证 |
| | | */ |
| | | private static HostnameVerifier getHostnameVerifier() { |
| | | HostnameVerifier hostnameVerifier = new HostnameVerifier() { |
| | | @Override |
| | | public boolean verify(String s, SSLSession sslSession) { |
| | | return true; |
| | | } |
| | | }; |
| | | return hostnameVerifier; |
| | | } |
| | | |
| | | /** |
| | | * description 忽略https证书验证 |
| | | */ |
| | | private static SSLSocketFactory getSSLSocketFactory() { |
| | | try { |
| | | SSLContext sslContext = SSLContext.getInstance("SSL"); |
| | | sslContext.init(null, getTrustManager(), new SecureRandom()); |
| | | return sslContext.getSocketFactory(); |
| | | } catch (Exception e) { |
| | | throw new RuntimeException(e); |
| | | } |
| | | } |
| | | |
| | | private static X509TrustManager getX509TrustManager() { |
| | | X509TrustManager trustManager = null; |
| | | try { |
| | | TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); |
| | | trustManagerFactory.init((KeyStore) null); |
| | | TrustManager[] trustManagers = trustManagerFactory.getTrustManagers(); |
| | | if (trustManagers.length != 1 || !(trustManagers[0] instanceof X509TrustManager)) { |
| | | throw new IllegalStateException("Unexpected default trust managers:" + Arrays.toString(trustManagers)); |
| | | } |
| | | trustManager = (X509TrustManager) trustManagers[0]; |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | |
| | | return trustManager; |
| | | } |
| | | |
| | | private static TrustManager[] getTrustManager() { |
| | | TrustManager[] trustAllCerts = new TrustManager[]{ |
| | | new X509TrustManager() { |
| | | @Override |
| | | public void checkClientTrusted(X509Certificate[] chain, String authType) { |
| | | } |
| | | |
| | | @Override |
| | | public void checkServerTrusted(X509Certificate[] chain, String authType) { |
| | | } |
| | | |
| | | @Override |
| | | public X509Certificate[] getAcceptedIssuers() { |
| | | return new X509Certificate[]{}; |
| | | } |
| | | } |
| | | }; |
| | | return trustAllCerts; |
| | | } |
| | | |
| | | } |