httpclient 支持代理和http & https
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的更多相关文章
- android httpClient 支持HTTPS的2种处理方式
摘自: http://www.kankanews.com/ICkengine/archives/9634.shtml 项目中Android https或http请求地址重定向为HTTPS的地址,相信很 ...
- Confluence 6 代理和 HTTPS 设置连接器
很多用户选择将 Confluence 运行在反向代理的后面,同时还启用了 HTTPS.将你的的 Confluence 反向代理配置正确就显得非常必要了,并且能够避免后期在使用 Confluence 遇 ...
- jdk动态代理和cglib动态代理底层实现原理详细解析(cglib动态代理篇)
代理模式是一种很常见的模式,本文主要分析cglib动态代理的过程 1. 举例 使用cglib代理需要引入两个包,maven的话包引入如下 <!-- https://mvnrepository.c ...
- Android 使Volley完美支持自定义证书的Https
其实在最早的版本里,Volley甚至是不支持https协议的,只能跑http,当然你也可以自己修改他的源码让他支持,如今volley的代码经过一些改进以后, 已经可以完美支持https协议了,无论是在 ...
- 基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)到底有什么区别。
基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)到底有什么区别. 我还是喜欢基于Schema风格的Spring事务管理,但也有很多人在用基于@Tras ...
- Spring -- <tx:annotation-driven>注解基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional)的区别。
借鉴:http://jinnianshilongnian.iteye.com/blog/1508018 基于JDK动态代理和CGLIB动态代理的实现Spring注解管理事务(@Trasactional ...
- 使Volley完美支持自定义证书的Https
其实在最早的版本里,Volley甚至是不支持https协议的,只能跑http,当然你也可以自己修改他的源码让他支持,如今volley的代码经过一些改进以后, 已经可以完美支持https协议了,无论是在 ...
- 使用Nginx反向代理和proxy_cache缓存搭建CDN服务器加快Web访问速度
碰到问题:移动用户访问web服务器www.osyunwei.com很慢解决办法:1.在移动机房放置一台nginx反向代理服务器2.通过域名DNS智能解析,所有移动用户访问www.osyunwei.co ...
- spring 如何决定使用jdk动态代理和cglib(转)
Spring1.2: 将事务代理工厂[TransactionProxyFactoryBean] 或 自动代理拦截器[BeanNameAutoProxyCreator] 的 proxyTargetCla ...
随机推荐
- ecshop之transport和jquery冲突之完美解决方案
众所周知:ecshop的transport.js文件和Jquery是冲突的,两个文件不能同时调用,现给出以下完美解决方案:原因分析:在transport.js文件中,大概 580行到590行之间,这个 ...
- Js控制iFrame切换加载网址
<html> <head> <title>Js控制 iFrame 切换加载网址</title> </head> <body> & ...
- asp.net的sql防注入和去除html标记的方法
一. // <summary> /// 过滤标记 /// </summary> /// <param name="NoHTML">包括HTML, ...
- POJ3461——Oulipo
1.题目大意:单字符串匹配问题 2.分析:经典KMP问题 存个模板QAQ #include <cstdio> #include <cstdlib> #include <c ...
- 剑指Offer 合并两个排序的链表
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路: 用2个新节点,一个用来存放新链表的头节点,另一个用来移动.当p1,p2有一个到尾部的 ...
- php源码安全加密之PHP混淆算法.
php源码安全加密的前世今生,本想发在教程区中.不知道怎么发,就写在这里面吧.PHP加密,解密是一直的话题,本人菜鸟,今天就简单向大家介绍一下并说说其中原理.提供一些加密的混淆算法.一\PHP的加密总 ...
- mac 下搭建php 编程环境全过程
1,打开终端, 设置root密码sudo passwd root输入密码 2, 安装 apachemac 自带apache 启动apachectl start重新启动apachectl restart ...
- COGS 2421.[HZOI 2016]简单的Treap 题解
题目大意: 给定n个数及其优先级,求对应的符合最小堆性质的Treap的先序遍历. n<=500000. 解法: 目前为止我只想到了三种解法,其中第三种是正解. 1.暴力1 以优先级为关键字排序, ...
- linux awk, xargs
awk , 很赞的教程:http://coolshell.cn/articles/9070.html xargs, http://blog.csdn.net/andy572633/article/de ...
- ndk学习15: IPC机制
Linux IPC机制 来自为知笔记(Wiz)