[HttpClient]SSL双向实例
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); } }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。