7. 最后关闭HttpClient资源.
public String doPost(String url, String params) {
String result = “”;
CloseableHttpClient httpclient = null;
CloseableHttpResponse response = null;
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
HttpSession session = request.getSession();
if (session != null) {
httpclient = (CloseableHttpClient) session.getAttribute(“httpclient”);
}
if (httpclient == null) {
httpclient = HttpClients.createDefault();
}
try {
HttpPost httppost = new HttpPost(url);
httppost.setHeader(“accept”, “/”);
httppost.setHeader(“connection”, “Keep-Alive”);
httppost.setHeader(“User-Agent”, “Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.71 Safari/537.36”);
if (params != null && !“”.equals(params)) {
MultipartEntityBuilder reqEntity = MultipartEntityBuilder.create();
reqEntity.setCharset(Charset.forName(“utf-8”));
String[] nameAndValue = params.split(“&”);
for (String s : nameAndValue) {
String[] keyAndvalue = s.split(“=”,2);
//String[] keyAndvalue = s.split(“=”);
StringBody value = new StringBody(“”, ContentType.TEXT_PLAIN);
if(keyAndvalue.length == 2) {
value = new StringBody(keyAndvalue[1], Charset.forName(“utf-8”));
//value = new StringBody(keyAndvalue[1], ContentType.TEXT_PLAIN);
}
reqEntity.addPart(keyAndvalue[0], value);
}
HttpEntity httpEntity = reqEntity.build();
httppost.setEntity(httpEntity);
}
response = httpclient.execute(httppost);
HttpEntity resEntity = response.getEntity();
if(resEntity != null) {
result = EntityUtils.toString(resEntity, “utf-8”);
}
EntityUtils.consume(resEntity);
//if (url.endsWith(“center/login”) || url.endsWith(“#forgetPswd”) || url.endsWith(“#register”)) {
session.setAttribute(“httpclient”, httpclient);
//}
//2017-08-24 解决由session过期导致请求返回会员未登录的问题
if(StringUtils.isNotBlank(result)){
boolean isJson = Common.isJson(result);
//有些请求不是json格式,比如医院动态
if(isJson){
JSONObject js = JSONObject.fromObject(result);
//有些result没有返回code
if(js.has(“code”)){
if(ErrorCode.LS_ILLEGAL_LOGIN.equals(js.getString(“code”))){
log.info(“【本次请求返回会员未登录】”+js.toString());
//将请求信息放入缓存
RCacheEnTity rCacheEnTity = new RCacheEnTity(url,params,new Date());
CachePool.getInstance().putCacheItem(“RC”, rCacheEnTity);
String openId = (String) request.getSession().getAttribute(“openId”);
log.info(“【重新登陆的openID】”+openId);
//进行重新登陆
String cxdl = doPost(WechatContext.getInstance().getServerUrl() + “center/wechatLogin”, “username=” + openId);
//将上次的请求信息取出
CacheItem cacheItem = (CacheItem) CachePool.getInstance().getCacheItem(“RC”);
RCacheEnTity rCacheEnTity2 = (RCacheEnTity) cacheItem.getEntity();
log.info(“【重新请求的URL】”+rCacheEnTity2.getUrl());
//重新发送上次的请求
String cxqq = doPost(rCacheEnTity2.getUrl(),rCacheEnTity2.getParams());
JSONObject cx = JSONObject.fromObject(cxqq);
//请求成功之后将缓存中的上次的请求信息去除
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
学习之门!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!