Spring中restTemplate忽略https证书的代码实现

 package myapp.util;
 
 import org.jetbrains.annotations.NotNull;
 import org.springframework.http.client.SimpleClientHttpRequestFactory;
 import org.springframework.web.client.RestTemplate;
 
 import javax.net.ssl.HttpsURLConnection;
 import javax.net.ssl.SSLContext;
 import javax.net.ssl.TrustManager;
 import javax.net.ssl.X509TrustManager;
 import java.io.IOException;
 import java.net.HttpURLConnection;
 import java.net.Proxy;
 import java.security.KeyManagementException;
 import java.security.NoSuchAlgorithmException;
 import java.security.SecureRandom;
 import java.security.cert.X509Certificate;
 
 /**
  * @author zhangyalong
  * @version 2019-03-24 19:19
  */
 public class HttpClientUtils {
 
     public static RestTemplate getInstance(Proxy proxy, int connTimeout, int readTimeout, boolean enableSslCheck) {
         final RestTemplate restTemplate = new RestTemplate();
 
         // sslIgnore
         SimpleClientHttpRequestFactory requestFactory;
         if (!enableSslCheck) {
             requestFactory = getUnsafeClientHttpRequestFactory();
         } else {
             requestFactory = new SimpleClientHttpRequestFactory();
         }
 
         // proxy
         if (proxy != null) {
             requestFactory.setProxy(proxy);
         }
 
         // timeout
         requestFactory.setConnectTimeout(connTimeout);
         requestFactory.setReadTimeout(readTimeout);
 
         restTemplate.setRequestFactory(requestFactory);
         return restTemplate;
     }
 
     private static SimpleClientHttpRequestFactory getUnsafeClientHttpRequestFactory() {
         TrustManager[] byPassTrustManagers = new TrustManager[]{new X509TrustManager() {
 
             public X509Certificate[] getAcceptedIssuers() {
                 return new X509Certificate[0];
             }
 
             public void checkClientTrusted(X509Certificate[] chain, String authType) {
             }
 
             public void checkServerTrusted(X509Certificate[] chain, String authType) {
             }
         }};
         final SSLContext sslContext;
         try {
             sslContext = SSLContext.getInstance("TLS");
             sslContext.init(null, byPassTrustManagers, new SecureRandom());
             sslContext.getSocketFactory();
         } catch (NoSuchAlgorithmException | KeyManagementException e) {
             throw new RuntimeException(e);
         }
 
         return new SimpleClientHttpRequestFactory() {
             @Override
             protected void prepareConnection(HttpURLConnection connection,
                                              @NotNull String httpMethod) throws IOException {
                 super.prepareConnection(connection, httpMethod);
                 if (connection instanceof HttpsURLConnection) {
                     ((HttpsURLConnection) connection).setSSLSocketFactory(
                             sslContext.getSocketFactory());
                 }
             }
         };
     }
 
     public static RestTemplate getInstance(Proxy proxy, boolean enableSsLCheck) {
         return getInstance(proxy, -1, -1, enableSsLCheck);
     }
 
 }
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值