github地址:AsyncHttpClient

API:API

1.X和2.X差别很大,我用的1.X中的最新版 1.9.39。

这是一个异步请求的工具,越简单越好,不喜欢再结合netty使用。AsyncHttpClient底层使用java线程池

this.applicationThreadPool = Executors.newCachedThreadPool(new ThreadFactory() {
public Thread newThread(Runnable r) {
Thread t = new Thread(r, "AsyncHttpClient-Callback");
t.setDaemon(true);
return t;
}
});

这样的线程池最大线程数没有限制(Integer.MAX_VALUE),就知道开开开线程,在某种情况下会很容易搞垮我们的系统,所以在下面的单例类中做了限制

configBuilder.setMaxConnections(2);

限制提交的数量。可以看出线程池中的线程是daemon的,当所有非daemon线程退出后jvm将退出!!!

写了个单例类,供参考

import com.ning.http.client.*;

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Future; /**
* Created by yhzh on 2016/9/19.
*/
public class MlsAsyncHttpClient {
private AsyncHttpClient client; private static class HttpClientHolder{
private static MlsAsyncHttpClient httpClient=new MlsAsyncHttpClient();
} private MlsAsyncHttpClient(){
AsyncHttpClientConfig.Builder configBuilder=new AsyncHttpClientConfig.Builder();
configBuilder.setMaxConnections(2);
/*使用默认值:
configBuilder.setConnectTimeout(3000);
configBuilder.setReadTimeout(5000);*/
configBuilder.setRequestTimeout(60000);
this.client=new AsyncHttpClient(configBuilder.build());
} public static MlsAsyncHttpClient getAsyncHttpClient(){
return HttpClientHolder.httpClient;
} public Future<Response> get(String url) {
return this.client.prepareGet(url).execute();
} public void get(String url, AsyncHandler resHandler) {
this.client.prepareGet(url).execute(resHandler);
} public Future<Response> post(String url) {
return this.client.preparePost(url).execute();
} public void post(String url,AsyncHandler resHandler) {
this.client.preparePost(url).execute(resHandler);
} private Request buildRequest(String url, Map<String,String> paramsMap){
RequestBuilder requestBuilder = new RequestBuilder();
if(paramsMap != null && paramsMap.size() > 0) {
Set<Map.Entry<String, String>> entrySet = paramsMap.entrySet();
Iterator<Map.Entry<String, String>> iterator = entrySet.iterator();
while(iterator.hasNext()) {
Map.Entry<String, String> entry = iterator.next();
if(entry.getKey() != null) {
requestBuilder.addFormParam(entry.getKey(), entry.getValue());
}
}
}
// 添加RequestHeader,key
requestBuilder.addHeader("Content-type", "application/x-www-form-urlencoded; charset=UTF-8");
requestBuilder.setMethod("POST");
requestBuilder.setUrl(url); return requestBuilder.build();
} public Future<Response> post(String url, Map<String,String> paramsMap) {
Request req=this.buildRequest(url,paramsMap); return this.client.executeRequest(req);
} public void post(String url, Map<String,String> paramsMap, AsyncHandler resHandler) {
Request req=this.buildRequest(url,paramsMap); this.client.executeRequest(req,resHandler);
//this.client.preparePost(url).execute(responseHandler);
}
}

测试代码

@Test
public void testSelectLoanResultOfLoanResultsOfZgController() throws InterruptedException {
CountDownLatch completionLatch = new CountDownLatch(2);
//com.ning.http.client.providers.netty.NettyAsyncHttpProvider
MlsAsyncHttpClient.getAsyncHttpClient().get("http://127.0.0.1:8081/assetmgmt/ploanouter/repayplan?lrid=0",new AsyncHandler() {
private ByteArrayOutputStream bytes = new ByteArrayOutputStream();
boolean done=false;
@Override
public STATE onStatusReceived(HttpResponseStatus status) throws Exception {
int statusCode = status.getStatusCode();
if (statusCode >= 500) {
return STATE.ABORT;
}
return STATE.CONTINUE;
} @Override
public STATE onHeadersReceived(HttpResponseHeaders httpResponseHeaders) throws Exception {
FluentCaseInsensitiveStringsMap str=httpResponseHeaders.getHeaders();
return STATE.CONTINUE;
} @Override
public STATE onBodyPartReceived(HttpResponseBodyPart httpResponseBodyPart) throws Exception {
bytes.write(httpResponseBodyPart.getBodyPartBytes());
return STATE.CONTINUE;
} @Override
public Object onCompleted() throws Exception {
String str=bytes.toString("utf-8");
System.out.println("get baidu:");
completionLatch.countDown();
return null;
} @Override
public void onThrowable(Throwable t){
if(!done){
completionLatch.countDown();
done=true;
}
System.out.println("get exception:"+t.getMessage());
}
}); Map<String,String> m=new HashMap<String,String>();
m.put("lrid","-1");
MlsAsyncHttpClient.getAsyncHttpClient().post("http://127.0.0.1:8080/assetmgmt/ploanouter/repayplan",m,new AsyncCompletionHandler() {
boolean done=false;
@Override
public Object onCompleted(Response response) throws Exception {
String str=response.getResponseBody();
String name=Thread.currentThread().getName();
boolean daemon=Thread.currentThread().isDaemon();
System.out.println("post baidu:");
completionLatch.countDown();
return null;
} @Override
public void onThrowable(Throwable t){
if(!done){
completionLatch.countDown();
done=true;
}
System.out.println("post exception:"+t.getMessage());
}
}); completionLatch.await();
System.out.println("异步请求结束!!!");
}

正如一开始所说(当所有非daemon线程退出后jvm将退出),所以我加了个CountDownLatch,在每个请求可以结束的地方

completionLatch.countDown();

最后

completionLatch.await();

完成退出。

其实如果允许请求无限等待,这样还是有可能导致程序阻塞在await这,可以使用

await(long timeout, TimeUnit unit)

设置时间等待,这个时候请求的响应可能会丢失(参数设置等问题),所以我设置了等待响应的时间

configBuilder.setRequestTimeout(60000);

什么东西还是明确的好,各种参数都要经过调试才能确定

参考文章:

1. java之httpClient 3.x、AsyncHttpClient1.9.x使用总结

2. Async Http Client:异步HTTP和WebSocket客户端

AsyncHttpClient使用的更多相关文章

  1. 异步网络加载开源框架AsyncHttpClient使用

    AsyncHttpClient是异步的,但是有时候我们需要得到请求的结果集来返回给某个函数,由于是异步的,所以不能够直接return会去,所以可以定义一个interface来给调用AsyncHttpC ...

  2. AsyncHttpClient 源码分析

    上一篇文章从功能和用法上对AsyncHttpClient做了个大致介绍,今天我们和以往一样,从内部实现.原理的角度带领大家看看 其工作机制,以便加深理解.写程序越多,我发现每接触一个新东西,都会有强烈 ...

  3. android-async-http AsyncHttpClient介绍

    前一阵子刚搬了家,加上公司要发新版本,所以一直比较忙,文章也好几周没更新了.难得这个周末有空,正好周内偶然间闲逛 发现这个很不错的第三方开源类库,针对Android开发中发送http请求的. 在And ...

  4. FastJson和AsyncHttpCLient

    Android的展示数据,除了上章所讲的本地存储外,大部分数据都来自于网络.首先介绍一下Android APP开发常见的网络操作方式.从网络层面上有底层的tcp/ip,也就是我们常见的socket套接 ...

  5. Android应用中使用AsyncHttpClient来异步网络数据(转载)

    摘要: 首先下载AsyncHttpClient的库文件,可以自行搜索,可以到下面地址下载 http://download.csdn.net/detail/xujinyang1234/5767419 测 ...

  6. asynchttpClient框架关于多文件批量上传的问题,改用xUtil

    RequestParams params = new RequestParams(); params.add("ordernum",ordernum); params.add(&q ...

  7. AsyncHttpClient

    package com.jingle.httpstudy;   import org.apache.http.Header;   import android.app.Activity; import ...

  8. Asynchttpclient开源框架下载图片和文本,于Volley和Glide开源框架的区别。

    AsyncHttpClient是一款比较流行的Android异步网路加载库,在github上的网址是:https://github.com/loopj/android-async-httpAsyncH ...

  9. android AsyncHttpClient 开源框架的使用

    AsyncHttpClient 1.在很多时候android都需要进行网络的操作,而android自带的HttpClient可以实现,但要进行很多网络连接的时候(如:下载很多图片),就需要线程池来进行 ...

  10. 强大的网络通信框架(不实现缓存)--第三方开源--AsyncHttpClient

    AsyncHttpClient是一款比较流行的Android异步网路加载库,在github上的网址是:https://github.com/loopj/android-async-http但是Asyn ...

随机推荐

  1. Dynamic CRM 2016 的备份/恢复/重新部署

    参考:1.https://community.dynamics.com/crm/b/crmviking/archive/2016/02/03/backup-and-restore-strategies ...

  2. Java基础(三)面向对象(下)

    接口 接口中成员修饰符是固定的: 成员常量:public static final 成员函数:public abstract 通过接口间接实现了多重继承 接口的特点 接口是对外暴露的规则 接口是程序的 ...

  3. vue 实站技巧总结

    多个页面都使用的到方法,放在 vue.prototype上会很方便 刚接触 vue的时候做过一件傻事,因为封装了一个异步请求接口post,放在 post.js文件里面,然后在每个需要使用异步请求的页面 ...

  4. 【原创 Hadoop&Spark 动手实践 11】Spark Streaming 应用与动手实践

    [原创 Hadoop&Spark 动手实践 11]Spark Streaming 应用与动手实践 目标: 1. 掌握Spark Streaming的基本原理 2. 完成Spark Stream ...

  5. Android Studio创建JAR/AAR库

    [时间:2017-09] [状态:Open] [关键词:Android,Android Studio,gradle,jar,aar,library] 0 引言 最近在工作中遇到了升级Android S ...

  6. 【GMT43智能液晶模块】例程十:DMA实验——存储器到存储器的传输

    实验原理: DMA(直接存储器访问)传输不需要占用CPU,可以在存储器至存储器实现高速的数据 传输.本实验采用DMA2控制器的数据流0,选用通道0进行数据传输.通过液晶控制传输 和结果显示. 示例截图 ...

  7. docker容器里设置中文时区

    本文讨论docker容器里中文时区的问题,总所周知docker hub上的镜像默认都是英文时区的,在国人使用过程当中需要将时区设置成中文,我原来光配置/etc/localtime了date显示的时间也 ...

  8. 运行yarn的时候提示 node不是内部或外部命令

    背景:准备react native 搭建,装完nodejs  npm 重启cmd,再次管理员运行即可!

  9. 应用程序连接hbase报错:java.net.SocketTimeoutException: callTimeout=60000

    背景说明: 今天对生产环境hbase增加了节点,下午的时候一个同事反馈,应用程序后台报错,如下: Tue Feb 26 17:35:35 CST 2019, null, java.net.Socket ...

  10. C#串口小助手

    做技术的通病,什么都想学,什么都想亲手做一遍.不然总感觉心里不踏实. 考研期间,利用晚上一点时间,照葫芦画瓢,练习使用c#快速开发一个简单的串口小助手. 这种前后端分离的设计方法,大大提高了开发速度, ...