上篇文章说道httpclient不能直接访问https的资源,此次就来模拟一下环境,而后配置https测试一下。在前面的文章中,分享了一篇本身生成并在tomcat中配置ssl的文章《Tomcat配置SSL》,你们能够据此来在本地配置https。我已经配置好了,效果是这样滴:java

能够看到已经信任该证书(显示浅绿色小锁),浏览器能够正常访问。如今咱们用代码测试一下:浏览器
- public static void main(String[] args) throws ParseException, IOException, KeyManagementException, NoSuchAlgorithmException, HttpProcessException {
- String url = "https://sso.tgb.com:8443/cas/login";
- String body = send(url, null, "utf-8");
- System.out.println("交易响应结果:");
- System.out.println(body);
- System.out.println("-----------------------------------");
- }

发现抛出了异常,我知道的有两种方案(也许还有我不知道的方案),这里介绍第一种方案,也是用的比较多的方案——绕过证书验证。直接看代码吧:tomcat
- public static SSLContext createIgnoreVerifySSL() throws NoSuchAlgorithmException, KeyManagementException {
- SSLContext sc = SSLContext.getInstance("SSLv3");
-
-
- 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;
- }
而后修改原来的send方法:app
- public static String send(String url, Map<String,String> map,String encoding) throws KeyManagementException, NoSuchAlgorithmException, ClientProtocolException, IOException {
- String body = "";
-
- SSLContext sslcontext = createIgnoreVerifySSL();
-
-
- Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>create()
- .register("http", PlainConnectionSocketFactory.INSTANCE)
- .register("https", new SSLConnectionSocketFactory(sslcontext))
- .build();
- PoolingHttpClientConnectionManager connManager = new PoolingHttpClientConnectionManager(socketFactoryRegistry);
- HttpClients.custom().setConnectionManager(connManager);
-
-
- CloseableHttpClient client = HttpClients.custom().setConnectionManager(connManager).build();
- / CloseableHttpClient client = HttpClients.createDefault();
-
-
- HttpPost httpPost = new HttpPost(url);
-
-
- List<NameValuePair> nvps = new ArrayList<NameValuePair>();
- if(map!=null){
- for (Entry<String, String> entry : map.entrySet()) {
- nvps.add(new BasicNameValuePair(entry.getKey(), entry.getValue()));
- }
- }
-
- httpPost.setEntity(new UrlEncodedFormEntity(nvps, encoding));
-
- System.out.println("请求地址:"+url);
- System.out.println("请求参数:"+nvps.toString());
-
-
-
- httpPost.setHeader("Content-type", "application/x-www-form-urlencoded");
- httpPost.setHeader("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
-
-
- CloseableHttpResponse response = client.execute(httpPost);
-
- HttpEntity entity = response.getEntity();
- if (entity != null) {
-
- body = EntityUtils.toString(entity, encoding);
- }
- EntityUtils.consume(entity);
-
- response.close();
- return body;
- }
如今再进行测试,发现果真通了。socket
下篇介绍另外一种方案,应对本身生成的证书,敬请期待。ide
转自 http://blog.csdn.net/xiaoxian8023post