[HttpClient]SSL双向实例
2015-02-13 23:46
176 查看
package com.jerry.httpclient; import java.io.File; import java.io.FileInputStream; import java.security.KeyStore; import javax.net.ssl.SSLContext; import org.apache.http.HttpEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.conn.ssl.SSLConnectionSocketFactory; import org.apache.http.conn.ssl.SSLContexts; import org.apache.http.conn.ssl.TrustSelfSignedStrategy; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; /** * * @author Jerry * @date 2015年2月12日 下午11:38:33 */ public class SSLDemo { public static final String KEY_STORE_TYPE_JKS = "jks"; public static final String KEY_STORE_TYPE_P12 = "PKCS12"; public static void main(String[] args) throws Exception{ KeyStore keyStore = KeyStore.getInstance(KEY_STORE_TYPE_P12);//服务器发给浏览器的KeyStore KeyStore trustStore = KeyStore.getInstance(KEY_STORE_TYPE_JKS);//浏览器发给服务器的KeyStore FileInputStream input = new FileInputStream(new File("d:\\tomcat.keystore")); FileInputStream keyInput = new FileInputStream("d:\\mykey.p12"); trustStore.load(input, "123456".toCharArray()); keyStore.load(keyInput, "123456".toCharArray()); /* * 使用2个keystore创建sslcontext */ SSLContext sslContext = SSLContexts.custom().useTLS(). loadTrustMaterial(trustStore, new TrustSelfSignedStrategy()) .loadKeyMaterial(keyStore, "123456".toCharArray()) .build(); //通过sllcontext创建一个socket factory SSLConnectionSocketFactory sslFactory = new SSLConnectionSocketFactory(sslContext); CloseableHttpClient client = HttpClients.custom().setSSLSocketFactory(sslFactory).build(); HttpGet get = new HttpGet("https://localhost:8443/services"); System.out.println("executing request: " + get.getRequestLine()); CloseableHttpResponse response = client.execute(get); HttpEntity entity = response.getEntity(); if (entity != null) { System.out.println("response content lenght: " + entity.getContentLength()); } System.out.println(EntityUtils.toString(entity)); EntityUtils.consume(entity); } }
相关文章推荐
- Cookies,SSL,httpclient的多线程处理,HTTP方法
- httpclient结合http报文查看工具的一个实例
- TOMCAT-SSL双向认证-配置实例
- TOMCAT-SSL双向认证-配置实例
- 一个httpclient4实例跨域访问会报错,谁知道在什么情况下会出现这个问题?
- Cookies,SSL,httpclient的多线程处理,HTTP方法 (zt)
- HttpClient Post提交实例
- httpclient-4.1.3结合dom4j的完整演示实例
- Cookies,SSL,httpclient的多线程处理,HTTP方法
- java HttpClient Post实例
- java HttpClient Post实例
- HttpClient基本用法以及HTTP站点认证实例
- HTTP BASIC认证,抢先认证介绍和 HttpClient 4.1.1 实例
- httpclient ssl
- HttpClient入门实例之简单的pdf文件爬虫
- httpclient使用实例
- java Android Client客户端 SSL 证书 私钥 公钥 安全 双向认证 怎么解决?
- Cookies,SSL,httpclient的多线程处理,HTTP方法
- android webview & httpclient 处理 ssl (https)验证
- https应用:避免HttpClient的”javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated”异常