HttpClient绕过Https请求

使用的jar包版本

@SuppressWarnings("deprecation")
	public static String httpVivoGet(String url,String cookie,String tk) throws Exception{
		String result = null;
		HttpClient httpClient = new DefaultHttpClient();
		httpClient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 60000); // 连接超时时间
		httpClient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT, 90000);  // 数据传输时间
		//创建TrustManager
		X509TrustManager xtm = new X509TrustManager() {
			@SuppressWarnings("unused")
			public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {}
			@SuppressWarnings("unused")
			public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {}
			@Override
			public void checkClientTrusted(java.security.cert.X509Certificate[] arg0, String arg1)
					throws java.security.cert.CertificateException {
				
			}
			@Override
			public void checkServerTrusted(java.security.cert.X509Certificate[] arg0, String arg1)
					throws java.security.cert.CertificateException {
				
			}
			@Override
			public java.security.cert.X509Certificate[] getAcceptedIssuers() {
				return null;
			}
		};
		//这个好像是HOST验证
		X509HostnameVerifier hostnameVerifier = new X509HostnameVerifier() {
			public boolean verify(String arg0, SSLSession arg1) {
				return true;
			}
			public void verify(String arg0, SSLSocket arg1) throws IOException {}
			public void verify(String arg0, String[] arg1, String[] arg2) throws SSLException {}
			@SuppressWarnings("unused")
			public void verify(String arg0, X509Certificate arg1) throws SSLException {}
			@Override
			public void verify(String arg0, java.security.cert.X509Certificate arg1) throws SSLException {
				
			}
		};
		
		//TLS1.0与SSL3.0基本上没有太大的差别,可粗略理解为TLS是SSL的继承者,但它们使用的是相同的SSLContext
		SSLContext ctx = SSLContext.getInstance("TLS");
		//使用TrustManager来初始化该上下文,TrustManager只是被SSL的Socket所使用
		ctx.init(null, new TrustManager[] { xtm }, null);
		//创建SSLSocketFactory
		SSLSocketFactory socketFactory = new SSLSocketFactory(ctx);
		socketFactory.setHostnameVerifier(hostnameVerifier);
		//通过SchemeRegistry将SSLSocketFactory注册到我们的HttpClient上
		httpClient.getConnectionManager().getSchemeRegistry().register(new Scheme("https", socketFactory, 443));
		
		HttpGet get = new HttpGet(url);
		// 设置请求头
		//get.setHeader("Content-type", "application/x-www-form-urlencoded; charset=utf-8");
		get.setHeader("Cookie",cookie);
		get.setHeader("tk",tk);
		HttpResponse response = httpClient.execute(get);
		result = reponse2String(response);	
		// 关闭
        httpClient.getConnectionManager().shutdown();
		return result;
	}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值