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. STAR-H1208M集线器不支持同时挂载多个nfs

    今天在两个触摸屏上都加入了开机加载nfs的操作. 没想到会出现以下错误: pmap_getmaps.c: rpc problem: RPC: Unable to receive; errno = Co ...

  2. ActionBar使用

    在Android3.0之后,Google对UI导航设计上进行了一系列的改革,其中有一个非常好用的新功能就是引入的ActionBar,他用于取代3.0之前的标题栏,并提供更为丰富的导航效果. 一.添加A ...

  3. OpenCV成长之路(8):直线、轮廓的提取与描述

    基于内容的图像分析的重点是提取出图像中具有代表性的特征,而线条.轮廓.块往往是最能体现特征的几个元素,这篇文章就针对于这几个重要的图像特征,研究它们在OpenCV中的用法,以及做一些简单的基础应用. ...

  4. OpenCV图像的二值化

    图像的二值化: 与边缘检测相比,轮廓检测有时能更好的反映图像的内容.而要对图像进行轮廓检测,则必须要先对图像进行二值化,图像的二值化就是将图像上的像素点的灰度值设置为0或255,这样将使整个图像呈现出 ...

  5. huffman编码压缩算法(转)

    参考:http://blog.csdn.net/sunmenggmail/article/details/7598012 笔试时遇到的一道题.

  6. 多版本python共存

    当不同版本python之间相互不能兼容时,可以使用virtualenv创建不同版本python的虚拟环境 当没有指定python解释器时(如下-p 即为指定的python版本),将使用默认的全局pyt ...

  7. BZOJ 1468: Tree

    Description 真·树,问距离不大于 \(k\) 的点对个数. Sol 点分治. 同上. Code /********************************************* ...

  8. 23 使用环境 UsageEnvironment——Live555源码阅读

    23 使用环境 UsageEnvironment——Live555源码阅读(三)UsageEnvironment 23 使用环境 UsageEnvironment——Live555源码阅读(三)Usa ...

  9. ubuntu系统安装PHP扩展

    GD库的安装 sudo apt-get install php5-gd sudo apt-get install php5-gd sudo /etc/init.d/apache2 restart CU ...

  10. dtw算法优化(重写C语言版本)

    1.缩小搜索范围 2.降低内存消耗