使用 jdk1.8 lambda 表达式对 HttpClient 进行封装

本贴最后更新于 2834 天前,其中的信息可能已经时异事殊

1、使用 jdk lambda 表达式对 HttpClient 进行封装
2、HttpClient 的版本为 4.5.1
3、支持 http 和 https

import org.apache.http.HttpEntity;
import org.apache.http.HttpStatus;
import org.apache.http.NameValuePair;
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.methods.HttpRequestBase;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.ssl.SSLContextBuilder;
import org.apache.http.util.EntityUtils;

import javax.net.ssl.SSLContext;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.GeneralSecurityException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.logging.Logger;

/**

  • 说明: HttpClient 工具类
  • httpsclient 版本:4.5.1
  • @author xiaoting
  • Created by 2017-04-06 13:56

/
public class HttpClientUtil {
/

* 日志
/
private static final Logger log = Logger.getLogger("lavasoft");
/
*
* 请求编码
/
private static final String CHARSET_UTF_8 = "UTF-8";
/
*
* json 头
/
private static final String CONTENT_TYPE_JSON = "application/json";
/
*
* xml 请求
/
private static final String CONTENT_TYPE_XML = "text/xml";
/
*
* 连接池
/
private static PoolingHttpClientConnectionManager connMgr;
/
*
* 请求配置
*/
private static RequestConfig requestConfig;

/** * 超时时间 */ private static final int MAX_TIMEOUT = 7000; static { // 设置连接池 connMgr = new PoolingHttpClientConnectionManager(); // 设置连接池大小 connMgr.setMaxTotal(100); connMgr.setDefaultMaxPerRoute(connMgr.getMaxTotal()); /*校验链接*/ connMgr.setValidateAfterInactivity(1000); RequestConfig.Builder configBuilder = RequestConfig.custom(); // 设置连接超时 configBuilder.setConnectTimeout(MAX_TIMEOUT); // 设置读取超时 configBuilder.setSocketTimeout(MAX_TIMEOUT); // 设置从连接池获取连接实例的超时 configBuilder.setConnectionRequestTimeout(MAX_TIMEOUT); requestConfig = configBuilder.build(); } /** * 发送get请求 * * @param url url * @return */ public static String get(String url) { return doGet(url, new HashMap<>()); } /** * 发送get请求 * * @param url url * @return */ public static String getHttps(String url) { return doGet(url, new HashMap<>(), false); } /** * 发送get请求 https * * @param url url * @return */ public static String getHttps(String url, Map<String, Object> params) { return doGet(url, params, false); } public static String doGet(String url, Map<String, Object> params, boolean bl) { log.info("____请求参数:" + params.toString()); String param = getStringBuffer(params); String finalApiUrl = url + param; return HttpClient.domain(httpClient -> { HttpGet httpGet = new HttpGet(finalApiUrl); return execute(httpClient, httpGet); }, bl); } /** * 发送 GET 请求(HTTP),K-V形式 * * @param url * @param params * @return */ public static String doGet(String url, Map<String, Object> params) { return doGet(url, params, true); } private static String getStringBuffer(Map<String, Object> params) { if (MapUtil.isNotNull(params)) { StringBuffer param = new StringBuffer(); int i = 0; for (String key : params.keySet()) { if (i == 0) { param.append("?"); } else { param.append("&"); } param.append(key).append("=").append(params.get(key)); i++; } return param.toString(); } else { return ""; } } /** * 发送post请求 * * @param url post url * @param params post参数 * @return */ public static String post(String url, Map<String, Object> params) { log.info("____请求参数:" + params.toString()); return HttpClient.domain(httpClient -> { HttpPost httpPost = httpPostHandler(url, params); return execute(httpClient, httpPost); }, true); } /** * 发送post请求 * * @param url post url * @return */ public static String post(String url) { return post(url, new HashMap<>()); } /** * post json数据 * * @param url * @param jsonStr * @return */ public static String postJson(String url, String jsonStr) { log.info("____请求参数:" + jsonStr); return HttpClient.domain(httpClient -> { HttpPost httpPost = new HttpPost(url); StringEntity stringEntity; try { stringEntity = new StringEntity(jsonStr); } catch (UnsupportedEncodingException e) { return null; } httpPost.setHeader("Content-Type", CONTENT_TYPE_JSON); httpPost.setEntity(stringEntity); return execute(httpClient, httpPost); }, true); } /** * 发送 SSL POST 请求(HTTPS),K-V形式 * * @param apiUrl API接口URL * @param params 参数map * @return */ public static String doPostSSL(String url, Map<String, Object> params) { log.info("____请求参数:" + params.toString()); return HttpClient.domain(httpClient -> { HttpPost httpPost = httpPostHandler(url, params); return execute(httpClient, httpPost); }, false); } /** * 发送 SSL POST 请求(HTTPS),JSON形式 * * @param apiUrl API接口URL * @param json JSON对象 * @return */ public static String doPostSSL(String apiUrl, Object json) { log.info("____请求参数:" + json); return HttpClient.domain(httpClient -> { HttpPost httpPost = new HttpPost(apiUrl); StringEntity stringEntity; stringEntity = new StringEntity(json.toString(), CHARSET_UTF_8); stringEntity.setContentEncoding(CHARSET_UTF_8); httpPost.setHeader("Content-Type", CONTENT_TYPE_JSON); httpPost.setEntity(stringEntity); return execute(httpClient, httpPost); }, false); } /* public static String postXml(String url, Object xmlObj) { String res = null; CloseableHttpClient httpClient = HttpClients.createDefault(); try { HttpPost httpPost = new HttpPost(url); //解决XStream对出现双下划线的bug XStream xStreamForRequestPostData = new XStream(new DomDriver("UTF-8", new XmlFriendlyNameCoder("-_", "_"))); //将要提交给API的数据对象转换成XML格式数据Post给API String postDataXML = xStreamForRequestPostData.toXML(xmlObj); //得指明使用UTF-8编码,否则到API服务器XML的中文不能被成功识别 StringEntity postEntity = new StringEntity(postDataXML, "UTF-8"); httpPost.addHeader("Content-Type", CONTENT_TYPE_XML); httpPost.setEntity(postEntity); res = execute(httpClient, httpPost); } finally { doHttpClientClose(httpClient); } return res; }*/ private static HttpPost httpPostHandler(String url, Map<String, Object> params) { HttpPost httpPost = new HttpPost(url); List<NameValuePair> naps = new ArrayList<>(); if (MapUtil.isNotNull(params)) { for (Map.Entry<String, Object> entry : params.entrySet()) { naps.add(new BasicNameValuePair(entry.getKey(), entry.getValue().toString())); } } try { httpPost.setEntity(new UrlEncodedFormEntity(naps, CHARSET_UTF_8)); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return httpPost; } private static String execute(CloseableHttpClient httpClient, HttpRequestBase httpGetOrPost) { String res = null; CloseableHttpResponse response = null; try { httpGetOrPost.setConfig(requestConfig); log.info("________请求url:" + httpGetOrPost.getURI()); response = httpClient.execute(httpGetOrPost); log.info("________返回code:" + response.getStatusLine().getStatusCode()); if (response.getStatusLine().getStatusCode() != HttpStatus.SC_OK) { return null; } HttpEntity entity = response.getEntity(); res = EntityUtils.toString(entity, CHARSET_UTF_8); log.info("________返回值:" + res); } catch (IOException e) { e.printStackTrace(); } finally { doResponseClose(response); } return res; } private static void doHttpClientClose(CloseableHttpClient httpClient) { if (httpClient != null) { try { httpClient.close(); } catch (IOException e) { e.printStackTrace(); } } } private static void doResponseClose(CloseableHttpResponse response) { if (response != null) { try { response.close(); } catch (IOException e) { e.printStackTrace(); } } } public interface HttpClientInterface<T> { T domain(CloseableHttpClient httpClient); } static class HttpClient { /** * @param interfaces 具体的操作接口 * @param bl 是否是http请求,false https true http * @param <T> 返回泛型 * @return */ public static <T extends Object> T domain(HttpClientInterface<T> interfaces, boolean bl) { // 返回值 T object; CloseableHttpClient httpClient; if (bl) { httpClient = HttpClients.createDefault(); } else { httpClient = HttpClients.custom().setSSLSocketFactory(createSSLConnSocketFactory()). setConnectionManager(connMgr).setDefaultRequestConfig(requestConfig). setConnectionManagerShared(true).build(); } try { // 业务操作 object = interfaces.domain(httpClient); } finally { doHttpClientClose(httpClient); } return object; } } /** * 创建SSL安全连接 * * @return */ private static SSLConnectionSocketFactory createSSLConnSocketFactory() { SSLConnectionSocketFactory sslsf = null; try { SSLContext sslContext = new SSLContextBuilder().loadTrustMaterial(null, (chain, authType) -> true).build(); sslsf = new SSLConnectionSocketFactory(sslContext, (arg0, agr1) -> true); } catch (GeneralSecurityException e) { e.printStackTrace(); } return sslsf; }

}

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 161 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 692 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖 • 1 关注
  • 笔记

    好记性不如烂笔头。

    310 引用 • 794 回帖
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    124 引用 • 74 回帖
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 8 关注
  • CodeMirror
    2 引用 • 17 回帖 • 161 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    173 引用 • 518 回帖
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 1 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 247 关注
  • Outlook
    1 引用 • 5 回帖
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖 • 1 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    88 引用 • 139 回帖
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 82 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 55 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    494 引用 • 928 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 568 关注
  • OpenCV
    15 引用 • 36 回帖
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 4 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    63 引用 • 289 回帖 • 2 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    170 引用 • 1529 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 652 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 289 关注