httpclient https请求跳过验证

/**
     * https请求用
     * 
     * @param ip
     * @param port
     * @return
     */
    public static CloseableHttpClient getHttpsClient(String ip, int port) {
	CloseableHttpClient httpclient = null;

	try {
	    // 采用绕过验证的方式处理https请求
	    SSLContext sslcontext = createIgnoreVerifySSL();
	    // 设置协议http和https对应的处理socket链接工厂的对象
	    Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>create()
		    .register("http", PlainConnectionSocketFactory.INSTANCE)
		    .register("https", new SSLConnectionSocketFactory(sslcontext)).build();
	    PoolingHttpClientConnectionManager connManager = new PoolingHttpClientConnectionManager(
		    socketFactoryRegistry);

	    CookieStore cookieStore = new BasicCookieStore();
	    HttpClientContext localContext = HttpClientContext.create();
	    localContext.setCookieStore(cookieStore);

	    httpclient = HttpClients.custom().setConnectionManager(connManager).build();

	    if (ip != null && !"".equals(ip)) {
		HttpHost proxy = new HttpHost(ip, port);
		DefaultProxyRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxy);
		httpclient = HttpClients.custom().setConnectionManager(connManager).setRoutePlanner(routePlanner)
			.build();
	    }
	} catch (KeyManagementException e) {
	    e.printStackTrace();
	} catch (NoSuchAlgorithmException e) {
	    e.printStackTrace();
	}

	return httpclient;
    }

    /**
     * 绕过验证
     * 
     * @return
     * @throws NoSuchAlgorithmException
     * @throws KeyManagementException
     */
    public static SSLContext createIgnoreVerifySSL() throws NoSuchAlgorithmException, KeyManagementException {
	SSLContext sc = SSLContext.getInstance("SSLv3");

	// 实现一个X509TrustManager接口,用于绕过验证,不用修改里面的方法
	X509TrustManager trustManager = new X509TrustManager() {
	    @Override
	    public void checkClientTrusted(java.security.cert.X509Certificate[] paramArrayOfX509Certificate,
		    String paramString) throws CertificateException {
	    }

	    @Override
	    public void checkServerTrusted(java.security.cert.X509Certificate[] paramArrayOfX509Certificate,
		    String paramString) throws CertificateException {
	    }

	    @Override
	    public java.security.cert.X509Certificate[] getAcceptedIssuers() {
		return null;
	    }
	};

	sc.init(null, new TrustManager[] { trustManager }, null);
	return sc;
    }


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值