import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
import java.security.KeyStore;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry; import javax.net.ssl.SSLContext; import org.apache.http.HttpEntity;
import org.apache.http.HttpHost;
import org.apache.http.HttpStatus;
import org.apache.http.NameValuePair;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.Credentials;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URIBuilder;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.conn.ssl.SSLContexts;
import org.apache.http.conn.ssl.TrustStrategy;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.protocol.HTTP;
import org.apache.http.util.EntityUtils; /**
* @author sprinng
* @Description jdk >=1.7 兼容http https
*
*/
public class HttpUtils { private static CloseableHttpClient httpClientBuilder=null; /**
* http 和 https
* @param useProxy 是否使用代理
* @param needCert 是否需要证书
* @return
*/
private static CloseableHttpClient createSSLClientDefault(boolean useProxy,boolean needCert) {
SSLConnectionSocketFactory sslsf = null;
try {
if(needCert){
InputStream instream = new FileInputStream(new File("D:/cert/client.p12"));
InputStream instream1 = new FileInputStream(new File("D:/cert/tbb.jks"));
KeyStore keyStore = KeyStore.getInstance("PKCS12");
KeyStore trustStore = KeyStore.getInstance("JKS");
try {
//设置客户端证书
keyStore.load(instream, "12345678".toCharArray());
//设置服务器证书
trustStore.load(instream1, "12345678".toCharArray());
} catch (Exception e) {
ECommonUtil.getLog().error("导入证书错误" + e);
} finally {
if (instream != null) {
instream.close();
}
if (instream1 != null) {
instream1.close();
}
}
SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(trustStore).loadKeyMaterial(keyStore, "12345678".toCharArray()).build();
sslsf = new SSLConnectionSocketFactory(sslContext,SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
}else{
SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, new TrustStrategy() {
@Override
public boolean isTrusted(X509Certificate[] chain, String authType)
throws CertificateException {
return true;
}
}).build();
sslsf = new SSLConnectionSocketFactory(sslContext,new String []{"TLSv1.2"}, null,SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
}
if(useProxy){
CredentialsProvider credsProvider = new BasicCredentialsProvider();
AuthScope authScope = new AuthScope(PropertiesUtil.properties.getProperty("proxy_host"),Integer.parseInt(PropertiesUtil.properties.getProperty("proxy_port")));
Credentials credentials = new UsernamePasswordCredentials(PropertiesUtil.properties.getProperty("proxy_user"), PropertiesUtil.properties.getProperty("proxy_password"));
credsProvider.setCredentials(authScope, credentials);
httpClientBuilder= HttpClients.custom().setSSLSocketFactory(sslsf).setDefaultCredentialsProvider(credsProvider).build();
}else{
httpClientBuilder= HttpClients.custom().setSSLSocketFactory(sslsf).build();
}
return httpClientBuilder;
} catch (Exception e) {
ECommonUtil.getLog().error("创建https导入证书错误"+e);
}
return HttpClients.createDefault();
} /**
*
* @param url 请求地址
* @param map 请求参数
* @param res 返回结果
* @param timeOut 超时时间(min)
* @param useProxy 是否使用代理
* @return
* @throws Exception
*/
public static String get(String url,Map<String,String> map, String res, int timeOut, boolean useProxy, boolean needCert) throws Exception{
RequestConfig config = null; CloseableHttpClient httpClient=null; CloseableHttpResponse response=null;
if(httpClientBuilder==null){
httpClient= HttpUtils.createSSLClientDefault(useProxy,needCert);
}else{
httpClient=httpClientBuilder;
}
URIBuilder uriBuilder=new URIBuilder(url);
for (Entry<String, String> entry : map.entrySet()) {
uriBuilder=uriBuilder.setParameter(entry.getKey(),entry.getValue());
}
URI uri=uriBuilder.build();
HttpGet httpGet=new HttpGet(uri);
try {
if(useProxy){
HttpHost proxy = new HttpHost(PropertiesUtil.properties.getProperty("proxy_host"), Integer.parseInt(PropertiesUtil.properties.getProperty("proxy_port")),"http");
config = RequestConfig.custom().setProxy(proxy).setConnectTimeout(timeOut * 1000 * 60).build();
}else{
config = RequestConfig.custom().setConnectTimeout(timeOut * 1000 * 60).build();
} httpGet.setConfig(config);
ECommonUtil.getLog().info("执行get请求" + httpGet.getRequestLine());
response = httpClient.execute(httpGet);
HttpEntity entity = response.getEntity();
if (entity != null) {
ECommonUtil.getLog().info("响应状态:"+ response.getStatusLine());
String rStr=EntityUtils.toString(entity,"UTF-8");
ECommonUtil.getLog().info("响应内容:" + rStr);
if(HttpStatus.SC_OK==response.getStatusLine().getStatusCode()){
res=rStr;
}
EntityUtils.consume(entity);
}
}catch (Exception e) {
ECommonUtil.getLog().info("http请求错误"+e);
throw e;
}finally{
if(httpGet!=null){
httpGet.releaseConnection();
}
if(response!=null){
response.close();
}
if(httpClient!=null){
httpClient.close();
}
}
return res;
} /**
*
* @param url 请求地址
* @param params 请求参数
* @param res 返回结果
* @param timeOut 超时时间(min)
* @param useProxy 是否使用代理
* @param needCert 是否使用证书
* @return
* @throws Exception
*/
@SuppressWarnings({ "deprecation", "unused" })
private static String post(String url, List<NameValuePair> params, String res, int timeOut, boolean useProxy, boolean needCert) throws Exception {
RequestConfig config = null;CloseableHttpClient httpClient=null; CloseableHttpResponse response=null;
if(httpClientBuilder==null){
httpClient= HttpUtils.createSSLClientDefault(useProxy,needCert);
}else{
httpClient=httpClientBuilder;
}
HttpPost httpPost = new HttpPost(url);
if(useProxy){
HttpHost proxy = new HttpHost(PropertiesUtil.properties.getProperty("proxy_host"), Integer.parseInt(PropertiesUtil.properties.getProperty("proxy_port")),"http");
config = RequestConfig.custom().setProxy(proxy).setConnectTimeout(timeOut * 1000 * 60).build();
}else{
config = RequestConfig.custom().setConnectTimeout(timeOut * 1000 * 60).build();
}
httpPost.setConfig(config);
// 设置类型
httpPost.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));
try {
response = httpClient.execute(httpPost);
if(302 == response.getStatusLine().getStatusCode()){
ECommonUtil.getLog().info(response.getLastHeader("Location").getValue());
post(response.getLastHeader("Location").getValue(), params, res, timeOut, useProxy,needCert);
}
HttpEntity entity = response.getEntity();
res = EntityUtils.toString(entity, "UTF-8");
ECommonUtil.getLog().info(res);
EntityUtils.consume(entity);
} catch (IOException e) {
ECommonUtil.getLog().info("请求异常"+e);
e.printStackTrace();
} finally {
if (response != null) {
response.close();
}
if (httpPost != null) {
httpPost.releaseConnection();
}
if (httpClient != null) {
httpClient.close();
}
}
return res;
} public static void main(String[] args) throws Exception {
//-----------post----------------
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("req", "{\"method\":\"checkMobile\",\"timestamp\":\"A100000000000001\",\"channelCode\":\"A1\",\"queryType\":\"1\",\"telephone\":\"15301929770\"}"));
// HttpUtilsDemo.post("http://www.baidu.com", params,"",5,true);
// HttpUtilsDemo.post("https://localhost/spdbSjptServer/service.cgi", params, "" , 5 ,false);
// HttpUtilsDemo.post("http://localhost:7070/spdbSjptServer/service.cgi", params, "" , 5 ,false);
//-----------get------------------
String method = "{\"method\":\"checkMobile\",\"timestamp\":\"A100000000000001\",\"channelCode\":\"A1\",\"queryType\":\"1\",\"telephone\":\"15301929770\"}";
Map<String, String> map = new HashMap<String, String>();
map.put("req", method);
// HttpUtilsDemo.get("https://localhost/spdbSjptServer/service.cgi", map,"",5,false);
HttpUtils.get("http://localhost:7070/spdbSjptServer/service.cgi", map, "", 5, false,false);
// HttpUtilsDemo.get("https://localhost/spdbSjptServer/service.cgi", map, "", 5, false,true);
// HttpUtilsDemo.get("http://www.baidu.com", map, "", 5, true,false);
} }
import java.io.IOException;
import java.util.Properties; public class PropertiesUtil {
public static final Properties properties = new Properties();
static {
try {
properties.load(PropertiesUtil.class.getClassLoader().getResourceAsStream("config.properties"));
} catch (IOException e) {
ECommonUtil.getLog().error("初始config配置文件失败");
}
}
}
import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Logger; public class ECommonUtil {
private static Logger LOG = Logger.getLogger(ECommonUtil.class); public static Logger getLog() {
return LOG;
} public static void printSQL(String sql, Object... params) {
getLog().info("SQL: " + sql);
getLog().info("PARAMS: [" + StringUtils.join(params, ",") + "]");
} }

httpclient 支持代理和http & https的更多相关文章

  1. android httpClient 支持HTTPS的2种处理方式

    摘自: http://www.kankanews.com/ICkengine/archives/9634.shtml 项目中Android https或http请求地址重定向为HTTPS的地址,相信很 ...

  2. Confluence 6 代理和 HTTPS 设置连接器

    很多用户选择将 Confluence 运行在反向代理的后面,同时还启用了 HTTPS.将你的的 Confluence 反向代理配置正确就显得非常必要了,并且能够避免后期在使用 Confluence 遇 ...

  3. jdk动态代理和cglib动态代理底层实现原理详细解析(cglib动态代理篇)

    代理模式是一种很常见的模式,本文主要分析cglib动态代理的过程 1. 举例 使用cglib代理需要引入两个包,maven的话包引入如下 <!-- https://mvnrepository.c ...

  4. Android 使Volley完美支持自定义证书的Https

    其实在最早的版本里,Volley甚至是不支持https协议的,只能跑http,当然你也可以自己修改他的源码让他支持,如今volley的代码经过一些改进以后, 已经可以完美支持https协议了,无论是在 ...

  5. 基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)到底有什么区别。

    基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)到底有什么区别. 我还是喜欢基于Schema风格的Spring事务管理,但也有很多人在用基于@Tras ...

  6. Spring -- <tx:annotation-driven>注解基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)的区别。

    借鉴:http://jinnianshilongnian.iteye.com/blog/1508018 基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional ...

  7. 使Volley完美支持自定义证书的Https

    其实在最早的版本里,Volley甚至是不支持https协议的,只能跑http,当然你也可以自己修改他的源码让他支持,如今volley的代码经过一些改进以后, 已经可以完美支持https协议了,无论是在 ...

  8. 使用Nginx反向代理和proxy_cache缓存搭建CDN服务器加快Web访问速度

    碰到问题:移动用户访问web服务器www.osyunwei.com很慢解决办法:1.在移动机房放置一台nginx反向代理服务器2.通过域名DNS智能解析,所有移动用户访问www.osyunwei.co ...

  9. spring 如何决定使用jdk动态代理和cglib(转)

    Spring1.2: 将事务代理工厂[TransactionProxyFactoryBean] 或 自动代理拦截器[BeanNameAutoProxyCreator] 的 proxyTargetCla ...

随机推荐

  1. 贝叶斯决策_bayes(新闻分类)

    1.简单例子引入 2.先验概率 3.后验概率 4.最小错误率决策 5.最小风险贝叶斯决策 1. 贝叶斯公式 2简单例子 正常情况下,我们可以快速的将街上的人分成男和女两类.这里街上的人就是我们观测到的 ...

  2. Hadoop之Storm命令

    Hadoop之Storm命令 1.storm核心概念 stream--->一列火车 tuple--->一节车厢 数据--->乘客 spout--->始发站 bolt---> ...

  3. 第24天 runtime

    面试时被问到一个问题,如何实现weak变量的自动置nil?当时也不知道. 今天在实现target-action模式时,如何调用SEL,刚开始只会PerformSelector,但不能传递多个参数,后来 ...

  4. Android 带清除功能的输入框控件ClearEditText,仿IOS的输入框

    转载请注明出处http://blog.csdn.net/xiaanming/article/details/11066685 今天给大家带来一个很实用的小控件ClearEditText,就是在Andr ...

  5. Maven的依赖范围

    Maven的依赖构件包含一个依赖范围属性,这个属性描述的是三套classpath的控制,即编译.测试.运行. 举个例子Junit依赖只是在测试范围(classpath)使用,而在运行的时候不使用,还有 ...

  6. 写给喜欢用Block的朋友(ios Block)

    作者:fengsh998原文地址:http://blog.csdn.net/fengsh998/article/details/38090205转载请注明出处如果觉得文章对你有所帮助,请通过留言或关注 ...

  7. Shape + Selector: Make a Shape as one item of the Selector

    Generally, I use a selector to select pictures or colors to render the normal and the pressed backgr ...

  8. U盘安装中标麒麟服务器操作系统 一 (NeoKylin 6.5)

    U盘安装中标麒麟服务器操作系统(NeoKylin 6.5) 首先需要下载中标麒麟服务器操作系统的iso镜像.我这里的是NeoKylin Linux A 6.5.iso 因为超过了4GB,百度网盘不支持 ...

  9. Webclent基本操作

    /** * @Title: webclientTest.java * @Package webclient * @Description: TODO(用一句话描述该文件做什么) * @author A ...

  10. Bootstrap之表格checkbox复选框全选

    效果图: HTML中无需添加额外的一列来表示复选框,而是由JS完成,所以正常的表格布局就行了: <table class="table table-bordered table-hov ...