http连接池https忽略证书认证

private static PoolingHttpClientConnectionManager manager; // 连接池管理类
    private static ScheduledExecutorService monitorExecutor = Executors.newScheduledThreadPool(1);;

    private static SSLContextBuilder builder = null;
    private static SSLConnectionSocketFactory sslSocketFactory = null;
    static {
        try {
            builder = new SSLContextBuilder();
            // 全部信任 不做身份鉴定
            builder.loadTrustMaterial(null, new TrustStrategy() {
                @Override
                public boolean isTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {
                    return true;
                }
            });
            sslSocketFactory = new SSLConnectionSocketFactory(builder.build(), new String[]{"SSLv2Hello", "SSLv3", "TLSv1", "TLSv1.2"}, null, NoopHostnameVerifier.INSTANCE);
        }catch(Exception e) {
            logger.error("初始化http连接池失败");
            e.printStackTrace();
        }
        
        ConnectionSocketFactory plainSocketFactory = PlainConnectionSocketFactory.getSocketFactory();
        Registry<ConnectionSocketFactory> registry = RegistryBuilder.<ConnectionSocketFactory>create()
                .register("http", plainSocketFactory)
                .register("https", sslSocketFactory)
                .build();
        // 创建ConnectionManager,添加Connection配置信息
        manager = new PoolingHttpClientConnectionManager(registry);
        // 设置连接参数
        manager.setMaxTotal(MAX_CONN); // 最大连接数
        manager.setDefaultMaxPerRoute(Max_PRE_ROUTE); // 路由最大连接数
        // 开启监控线程,对异常和空闲线程进行关闭
        monitorExecutor.scheduleAtFixedRate(new TimerTask() {
            @Override
            public void run() {
            
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我明白了。针对您的问题,我可以给您提供以下的代码示例: ```java import cn.hutool.http.HttpRequest; import cn.hutool.http.HttpResponse; import cn.hutool.http.HttpUtil; import javax.net.ssl.*; import java.security.cert.X509Certificate; import java.util.concurrent.TimeUnit; public class HttpClientDemo { public static void main(String[] args) { SSLContext sslContext = createIgnoreVerifySSL(); SSLConnectionSocketFactory socketFactory = new SSLConnectionSocketFactory(sslContext, NoopHostnameVerifier.INSTANCE); RegistryBuilder<ConnectionSocketFactory> builder = RegistryBuilder.<ConnectionSocketFactory>create(); builder.register("http", PlainConnectionSocketFactory.getSocketFactory()).register("https", socketFactory); PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(builder.build()); HttpClient httpClient = HttpClientBuilder.create().setConnectionManager(connectionManager).build(); HttpRequest httpRequest = HttpUtil.createGet("https://www.example.com/"); httpRequest.setConnectionRequestTimeout(5000); httpRequest.setConnectTimeout(5000); httpRequest.setSocketTimeout(5000); HttpResponse httpResponse = httpRequest.execute(httpClient); System.out.println(httpResponse.body()); } private static SSLContext createIgnoreVerifySSL() { SSLContext sslContext; try { sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, 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 null; } }}, null); } catch (Exception e) { throw new RuntimeException(e); } return sslContext; } } ``` 这个示例代码中,我们使用了 hutool 的 HttpClient,同时也对 HTTPS 请求中的证书进行了忽略处理。具体来说,我们使用了 hutool 的 `cn.hutool.http.HttpRequest` 对象发起 GET 请求。在进行 HTTPS 请求的时候,我们使用了一个自定义的忽略证书的 `SSLContext` 对象。由于我们采用了忽略证书的方式,因此牵扯到网络安全问题,建议在生产环境中谨慎使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值