AsyncHttpClient
package com.jingle.httpstudy;
import org.apache.http.Header;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import com.loopj.android.http.AsyncHttpClient;
import com.loopj.android.http.AsyncHttpResponseHandler;
import com.loopj.android.http.JsonHttpResponseHandler;
import com.loopj.android.http.RequestParams;
public
class
MainActivity
extends
Activity
{
private
String
URL
=
"http://192.168.0.11:8080/NovallService/login.action";
private
String
userName
=
"15995858188";
private
String
userPass
=
"aa97eba124ab0c029fb7d5c37a6141b0";
private
AsyncHttpClient
client;
@Override
protected
void
onCreate(Bundle
savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initButtonLogin();
initButtonOffLine();
}
private
void
initButtonOffLine()
{
Button
btnOffline
=
(Button)
findViewById(R.id.getOffLine);
btnOffline.setOnClickListener(new
OnClickListener()
{
@Override
public
void
onClick(View
v)
{
// getOffLine();
getOverRun();
}
});
}
private
void
initButtonLogin()
{
Button
btnLogin
=
(Button)
findViewById(R.id.login);
btnLogin.setOnClickListener(new
OnClickListener()
{
public
void
onClick(View
v)
{
asyncLogin();
}
});
}
private
void
getOverRun()
{
String
url
=
"http://192.168.0.11:8080/NovallService/getAllOverRun.action";
String
deviceIds
=
"4";
String
lastRequestDate
=
"2015-03-1617:40:00";
RequestParams
params
=
new
RequestParams();
params.put("deviceIds",
deviceIds);
// 设置请求的参数名和参数值 key-value pair
params.put("lastRequestDate",
lastRequestDate);// 设置请求的参数名和参数
// client.setTimeout(5000);
client.get(url,
new
JsonHttpResponseHandler()
{
public
void
onSuccess(int
statusCode,
Header[]
headers,
String
responseString)
{
Log.d("ace",
">>>>"
+
responseString
+
"<<<<");
}
@Override
public
void
onFailure(int
statusCode,
Header[]
headers,
String
responseString,
Throwable
throwable)
{
Log.d("ace",
">>>>"
+
"error"
+
"<<<<");
throwable.printStackTrace();
}
});
// client.get(url, params, new AsyncHttpResponseHandler() {
//
// public void onSuccess(int arg0, Header[] arg1, byte[] arg2) {
// Log.d("ace", new String(arg2));
// }
//
// public void onFailure(int arg0, Header[] arg1, byte[] arg2,
// Throwable arg3) {
// arg3.printStackTrace();
// }
// });
}
private
void
getOffLine()
{
String
url
=
"http://192.168.0.11:8080/NovallService/getAllOffLine.action";
String
deviceIds
=
"6";
String
lastRequestDate
=
"2015-03-1617:40:00";
// 创建请求参数的封装的对象
RequestParams
params
=
new
RequestParams();
params.put("deviceIds",
deviceIds);
// 设置请求的参数名和参数值 key-value pair
// params.put("lastRequestDate", lastRequestDate);// 设置请求的参数名和参数
client.get(url,
params,
new
AsyncHttpResponseHandler()
{
public
void
onSuccess(int
arg0,
Header[]
arg1,
byte[]
arg2)
{
Log.d("ace",
new
String(arg2));
}
public
void
onFailure(int
arg0,
Header[]
arg1,
byte[]
arg2,
Throwable
arg3)
{
arg3.printStackTrace();
}
});
}
private
void
asyncLogin()
{
client
=
new
AsyncHttpClient();
// 创建请求参数的封装的对象
RequestParams
params
=
new
RequestParams();
params.put("userName",
userName);
// 设置请求的参数名和参数值 key-value pair
params.put("password",
userPass);// 设置请求的参数名和参数
client.post(URL,
params,
new
AsyncHttpResponseHandler()
{
public
void
onSuccess(int
arg0,
Header[]
arg1,
byte[]
arg2)
{
if
(arg0
==
200)
{
Log.i("ace",
new
String(arg2));
// tv_result.setText(new String(responseBody)); // 设置显示的文本
}
}
public
void
onFailure(int
arg0,
Header[]
arg1,
byte[]
arg2,
Throwable
arg3)
{
arg3.printStackTrace();
}
});
// 查看 cookie 信息
// CookieSpec cookiespec = CookiePolicy.getDefaultSpec();
// Cookie[] cookies = cookiespec.match(LOGON_SITE, LOGON_PORT, "/",
// false,
// client.getState().getCookies());
// if (cookies.length == 0) {
// System.out.println("None");
// } else {
// for (int i = 0; i < cookies.length; i++) {
// System.out.println(cookies[i].toString());
// }
// }
}
}
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开源框架下载图片和文本,于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 ...
随机推荐
- (原)String类两种实例化的区别
String有两种实例化方式,一种是通过直接赋值的方式,另外一种是使用标准的new调用构造方法完成实例化. public class StringDemo { public static void m ...
- 快速反射DataTable
public class SetterWrapper<TTarget, TValue> { private Action<TTarget, TValue> _setter; p ...
- yii 10.16
什么是框架? a) 框架就是一个半成品,一个帮助我们完成业务流程的程序 b) 框架融合了很多的功能,但是不会给我们具体功能模块 c) 我们需要在框架的基础 ...
- Java初学(六)
一.final(最终)可以修饰类.方法.变量 特点:final修饰类,该类不能被继承 final修饰方法,该方法不能被重写(覆盖.重载.复写) final修饰变量,该变量不能被重新赋值. ...
- 织梦DedeCms用SQL语句调用数据库任意内容方法
织梦DedeCms给我们提供了大量调用标签,供我们调用各种数据,但提供再多的标签,也有满足不了我们的时候,这时我们可以用SQL语句,灵活调用我们需要的内容. 如何任意调用数据库中的内容呢?先举个例子: ...
- ps 倒影制作
首先打开PS并打开一张素材,这里我选择了山水图片,制作山峰在水中的倒影效果. 然后按下[Crrl+J]复制这个图层,如图: 接着按下[Ctrl+T]或者是[编辑][自由变换],打开[自由变换] ...
- c++实现加密和解密算法以及JNI技术的应用实例
#include "jiami.h" #include "jni.h" #include "com_test_start_CommonClassLoa ...
- BI就是报表?
实际上,报表只是BI的一部分,虽然BI应用的结果通常需要通过报表来展示,但是,BI绝对不仅仅是报表.其实,大家对这些概念的理解,如同15年前的ERP一样.1998年,国内两大巨头金蝶与用友都开始宣称从 ...
- Flip Game(dfs)
Flip Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 32384 Accepted: 14142 Des ...
- MyBatis 3源码分析
Mybatis3.2源码分析: 一.加载配置文件. 使用SAX解析配置文件.读取xml配置文件后,调用XMLConfigBuilder.parse()方法,在parse方法中再调用parseC ...