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 ...
随机推荐
- 【Java】的四种引用的区别
强引用:如果一个对象具有强引用,它就不会被垃圾回收器回收.即使当前内存空间不足,JVM 也不会回收它,而是抛出 OutOfMemoryError 错误,使程序异常终止.如果想中断强引用和某个对象之间的 ...
- [转]decorator(HTML装饰器)
原文地址:https://blog.csdn.net/jzh440/article/details/7770013 1>:每当遇到一个新的技术,首先我会问自己,这个技术是做神马的?用这个技术有神 ...
- sql server中的用户临时表和全局临时表的区别
临时表分为: 本地临时表,仅限于当前访问者访问,创建方法去如下:create table #TableName(表结构)储存于数据库tempdb内(硬盘),当前用户断开连接(把当前的),自动删除如果使 ...
- Java编程的逻辑 (91) - Lambda表达式
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...
- IDEA设置换行符为Unix编码格式,设置编码统一为UTF-8,自动生成serialVersionUID
设置换行符为Unix编码格式 设置编码统一为UTF-8 自动生成serialVersionUID.勾选"Serializable class without serialVersionUID ...
- nohup.out文件过大解决方法 定时任务清空
0.1和2分别表示标准输入.标准输出和标准错误信息输出,可以用来指定需要重定向的标准输入或输出. 在一般使用时,默认的是标准输出,既1.当我们需要特殊用途时,可以使用其他标号.例如,将某个程序的错误信 ...
- 第四百零六节,自定义用户表类来继承Django的用户表类,
第四百零六节,自定义用户表类来继承Django的用户表类, models.py from django.db import models # Create your models here. from ...
- macOS Sierra(10.12.6), odoo(11.0), Python(3.5.4)配置
欣闻odoo11支持python3环境了,赶紧在mac平台尝试一下: 前期设置,参考另篇文章:macOS Sierra 10.12.6 odoo 10.0 开发环境配置 因为odoo11尚未正式发布, ...
- 删除或修改本地Git保存的账号密码
win10 系统下进入 控制面板 > 用户帐户 > 管理你的凭据 选择 [Windows 凭据] git 保存的用户信息在普通凭据列表里 >>编辑>>>完成
- UCloud 机房的网络搭建(计蒜客初赛第五场)
UCloud 刚刚建立一个新机房,近日正在进行网络搭建.机房内有 nn 台服务器和 mm 个分线器,整个机房只有一个网线出口.分线器的作用是将一根网线转换成多根网线.蒜头君也知道每个分线器输出的最大网 ...