AsyncHttpClient使用
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使用的更多相关文章
- 异步网络加载开源框架AsyncHttpClient使用
AsyncHttpClient是异步的,但是有时候我们需要得到请求的结果集来返回给某个函数,由于是异步的,所以不能够直接return会去,所以可以定义一个interface来给调用AsyncHttpC ...
- AsyncHttpClient 源码分析
上一篇文章从功能和用法上对AsyncHttpClient做了个大致介绍,今天我们和以往一样,从内部实现.原理的角度带领大家看看 其工作机制,以便加深理解.写程序越多,我发现每接触一个新东西,都会有强烈 ...
- android-async-http AsyncHttpClient介绍
前一阵子刚搬了家,加上公司要发新版本,所以一直比较忙,文章也好几周没更新了.难得这个周末有空,正好周内偶然间闲逛 发现这个很不错的第三方开源类库,针对Android开发中发送http请求的. 在And ...
- FastJson和AsyncHttpCLient
Android的展示数据,除了上章所讲的本地存储外,大部分数据都来自于网络.首先介绍一下Android APP开发常见的网络操作方式.从网络层面上有底层的tcp/ip,也就是我们常见的socket套接 ...
- Android应用中使用AsyncHttpClient来异步网络数据(转载)
摘要: 首先下载AsyncHttpClient的库文件,可以自行搜索,可以到下面地址下载 http://download.csdn.net/detail/xujinyang1234/5767419 测 ...
- asynchttpClient框架关于多文件批量上传的问题,改用xUtil
RequestParams params = new RequestParams(); params.add("ordernum",ordernum); params.add(&q ...
- AsyncHttpClient
package com.jingle.httpstudy; import org.apache.http.Header; import android.app.Activity; import ...
- Asynchttpclient开源框架下载图片和文本,于Volley和Glide开源框架的区别。
AsyncHttpClient是一款比较流行的Android异步网路加载库,在github上的网址是:https://github.com/loopj/android-async-httpAsyncH ...
- android AsyncHttpClient 开源框架的使用
AsyncHttpClient 1.在很多时候android都需要进行网络的操作,而android自带的HttpClient可以实现,但要进行很多网络连接的时候(如:下载很多图片),就需要线程池来进行 ...
- 强大的网络通信框架(不实现缓存)--第三方开源--AsyncHttpClient
AsyncHttpClient是一款比较流行的Android异步网路加载库,在github上的网址是:https://github.com/loopj/android-async-http但是Asyn ...
随机推荐
- Dynamic CRM 2016 的备份/恢复/重新部署
参考:1.https://community.dynamics.com/crm/b/crmviking/archive/2016/02/03/backup-and-restore-strategies ...
- Java基础(三)面向对象(下)
接口 接口中成员修饰符是固定的: 成员常量:public static final 成员函数:public abstract 通过接口间接实现了多重继承 接口的特点 接口是对外暴露的规则 接口是程序的 ...
- vue 实站技巧总结
多个页面都使用的到方法,放在 vue.prototype上会很方便 刚接触 vue的时候做过一件傻事,因为封装了一个异步请求接口post,放在 post.js文件里面,然后在每个需要使用异步请求的页面 ...
- 【原创 Hadoop&Spark 动手实践 11】Spark Streaming 应用与动手实践
[原创 Hadoop&Spark 动手实践 11]Spark Streaming 应用与动手实践 目标: 1. 掌握Spark Streaming的基本原理 2. 完成Spark Stream ...
- Android Studio创建JAR/AAR库
[时间:2017-09] [状态:Open] [关键词:Android,Android Studio,gradle,jar,aar,library] 0 引言 最近在工作中遇到了升级Android S ...
- 【GMT43智能液晶模块】例程十:DMA实验——存储器到存储器的传输
实验原理: DMA(直接存储器访问)传输不需要占用CPU,可以在存储器至存储器实现高速的数据 传输.本实验采用DMA2控制器的数据流0,选用通道0进行数据传输.通过液晶控制传输 和结果显示. 示例截图 ...
- docker容器里设置中文时区
本文讨论docker容器里中文时区的问题,总所周知docker hub上的镜像默认都是英文时区的,在国人使用过程当中需要将时区设置成中文,我原来光配置/etc/localtime了date显示的时间也 ...
- 运行yarn的时候提示 node不是内部或外部命令
背景:准备react native 搭建,装完nodejs npm 重启cmd,再次管理员运行即可!
- 应用程序连接hbase报错:java.net.SocketTimeoutException: callTimeout=60000
背景说明: 今天对生产环境hbase增加了节点,下午的时候一个同事反馈,应用程序后台报错,如下: Tue Feb 26 17:35:35 CST 2019, null, java.net.Socket ...
- C#串口小助手
做技术的通病,什么都想学,什么都想亲手做一遍.不然总感觉心里不踏实. 考研期间,利用晚上一点时间,照葫芦画瓢,练习使用c#快速开发一个简单的串口小助手. 这种前后端分离的设计方法,大大提高了开发速度, ...