javax.net.ssl.SSLHandshakeException: java.security.cert.CertificateException: No subject alternat...

问题原因

访问https的网站,没有携带证书

解决方案

一、忽略证书

public RestTemplate dtRestTemplate() {
        RestTemplate restTemplate = null;
        try {
            SSLContext sslContext = SSLContext.getInstance("TLSv1.2");
            sslContext.init(null, disableSslCheck(), new java.security.SecureRandom());
            HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
            SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslContext, hostnameVerifier);
            RequestConfig requestConfig = RequestConfig.custom()
                .setConnectTimeout(TIMEOUT)
                .setConnectionRequestTimeout(TIMEOUT)
                .setSocketTimeout(TIMEOUT)
                .build();
            CloseableHttpClient sslInsecureClient = HttpClients.custom()
                .setDefaultRequestConfig(requestConfig)
                .setSSLSocketFactory(sslsf)
                .build();

            HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory();

            requestFactory.setHttpClient(sslInsecureClient);
            restTemplate = new RestTemplate(requestFactory);
        } catch (Exception ex) {
            LOG.error("restTemplate create failed:" + ex.getMessage());
        }
        return restTemplate;
    }

    private static TrustManager[] disableSslCheck() {
        return new TrustManager[] {
                new X509TrustManager() {
                    @Override
                    public void checkClientTrusted(X509Certificate[] chain, String authType)
                            throws CertificateException {
                    }

                    @Override
                    public void checkServerTrusted(X509Certificate[] chain, String authType)
                            throws CertificateException {
                    }

                    @Override
                    public X509Certificate[] getAcceptedIssuers() {
                        return new X509Certificate[0];
                    }
                }
        };
    }

二、获取对应网站的证书


public RestTemplate restTemplate() {
        RestTemplate restTemplate = null;
        CloseableHttpClient sslInsecureClient = null;
        try {
            SSLContext sslContext = SSLContext.getInstance("TLSv1.2");
            sslContext.init(null, getTrustManagerFactory().getTrustManagers(), new java.security.SecureRandom());
            HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
            SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslContext, hostnameVerifier);
            RequestConfig requestConfig = RequestConfig.custom()
                .setConnectTimeout(TIMEOUT)
                .setSocketTimeout(TIMEOUT)
                .setConnectionRequestTimeout(TIMEOUT)
                .build();
            sslInsecureClient = HttpClients.custom()
                .setSSLSocketFactory(sslsf)
                .setDefaultRequestConfig(requestConfig)
                .build();

            HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory();
            requestFactory.setHttpClient(sslInsecureClient);
            restTemplate = new RestTemplate(requestFactory);
        } catch (Exception ex) {
            LOG.error("create failed:", ex);
            if (!Objects.isNull(sslInsecureClient)) {
                try {
                    sslInsecureClient.close();
                } catch (IOException exx) {
                    LOG.error("close failed:", exx);
                }
            }
        }
        return restTemplate;
    }

 private static TrustManagerFactory getTrustManagerFactory() throws Exception {
        KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
        TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(
            TrustManagerFactory.getDefaultAlgorithm());
        InputStream inputStream = null;
        try {
            inputStream = RestTemplateConfig.class.getClassLoader().getResourceAsStream("证书地址");
            keyStore.load(inputStream, null);
            trustManagerFactory.init(keyStore);
        } catch (FileNotFoundException ex) {
            LOG.error("load key store file failed");
        } finally {
            if (inputStream != null) {
                inputStream.close();
            }
        }
        return trustManagerFactory;
    }

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值