AsyncHttpClient的使用

一、简介

AsyncHttpClient是Android中处理异步Http的方法。

二、特征

  1. 使用版本4.3.6的上游HttpClient而不是Android提供了DefaultHttpClient
  2. 兼容Android API 23和更高版本
  3. 创建异步 HTTP请求,在匿名回调中处理响应
  4. HTTP请求发生在UI线程之外
  5. 请求使用线程池来限制并发资源使用
  6. GET / POST params builder(RequestParams)
  7. 多部分文件上传,无需额外的第三方库
  8. 流式传输JSON,无需额外的库
  9. 小尺寸开销到您的应用程序,只有90kb的一切
  10. 自动智能请求重试针对优质移动连接进行了优化
  11. 二进制协议与 BinaryHttpResponseHandler
  12. 内置响应解析到JSON 中JsonHttpResponseHandler

三、AsyncHttpClient的使用

使用AsyncHttpClient首先需要插入第三方的依赖库
使用Gradle包下面的build.gradel中添加依赖库

dependencies {
  compile 'com.loopj.android:android-async-http:1.4.9'
}

AsyncHttpClient有两种使用方法,一是写一个内部方法使用,二是封装AsyncHttpClient方法,通过调用来实现此方法

1、内部方法

 //创建一个新AsyncHttpClient实例并发出请求
    AsyncHttpClient client = new AsyncHttpClient();
    //AsyncHttpClient中有get和post两种方法
    //第一个参数是所要获取接口,第二个参数是所发出的请求
    client.get("https://www.google.com", new TextHttpResponseHandler() {
        @Override
        public void onFailure(int statusCode, Header[] headers, String responseString, Throwable throwable) {
               //用Toast显示是否请求成功
              Toast.makeText(ShoudongActivity.this,"访问失败",Toast.LENGTH_SHORT).show();
            }

        @Override
        public void onSuccess(int statusCode, Header[] headers, String responseString) {
              Toast.makeText(ShoudongActivity.this,responseString,Toast.LENGTH_SHORT).show();
              //打印获取到的信息
              Log.e( "onSuccess: ", responseString+"+++++++++++++++++++++++++++++++++++");
          }
    });

2、创建一个类封装AsyncHttpClient———推荐使用

由于在一个项目中使用的接口过多,如果在每一个类中都写一个AsyncHttpClient方法,那么就会使整个项目的代码量过大,而且比较繁琐,所以封装一个AsyncHttpClient方法,在需要的时候调用会使代码量减少

建立一个静态的Http客户端,先建立一个类来封装AsyncHttpClient方法

public class HttpUtil {
    //先定义一个String类型来接收接口相同的部分
    private static final String BASE_URL = "http://192.168.1.101:8890/type/jason/action/";
    //建立静态的AsyncHttpClient
    private static AsyncHttpClient client = new AsyncHttpClient();
    //AsyncHttpClient中有get和post方法,需要用到public方法来修饰,以便调用
    public  static void get(String url, RequestParams params, AsyncHttpResponseHandler responseHandler){
        client.get(getAbsoluteUrl(url), params, responseHandler);
    }
    //post方法中HttpEntity参数是后面发送JSON格式所用到的一个方法
    public static void post(Context context,String url, HttpEntity entity, String contentType, AsyncHttpResponseHandler responseHandler) {
        client.post(context,getAbsoluteUrl(url),entity, contentType, responseHandler);
    }
    //单独写一个方法添加URL
    private static String getAbsoluteUrl(String url) {
        return BASE_URL + url;
    }

}

写完了封装AsyncHttpClient的方法类,那么接下来就要调用了

    //在RequestParams类用于可选的get或post参数添加
    RequestParams params=new RequestParams();
    //用键值对的输出方式传出,第一个参数是键,第二个参数是值
    params.put("params","{\"classify_id\":70,\"page\":1,\"page_count\":2}");
    //第二个参数是上面RequestParams传来的参数
    HttpUtil.get("getConfig", params, new TextHttpResponseHandler() {
       @Override
       public void onFailure(int statusCode, Header[] headers, String responseString, Throwable throwable) {
              Toast.makeText(ShoudongActivity.this,"访问失败",Toast.LENGTH_SHORT).show();
           }

       @Override
       public void onSuccess(int statusCode, Header[] headers, String responseString) {
            Toast.makeText(ShoudongActivity.this,responseString,Toast.LENGTH_SHORT).show();
            Log.e( "onSuccess: ", responseString+"+++++++++++++++++++++++++++++++++++");
           }
  });

AsyncHttpClient的post方法发送JSON格式参数
用封装的AsyncHttpClient

  //定义json对象
  JSONObject jsonObject=new JSONObject();
  try {
      //解析json数据
        jsonObject.put("Blower", 1);
      } catch (JSONException e) {
          e.printStackTrace();
      }
    //封装方法中post的参数
   ByteArrayEntity entity = null;
   try {
        entity = new ByteArrayEntity(jsonObject.toString().getBytes("UTF-8"));
        //用application/json向其传达这是json类型的接口数据
        entity.setContentType(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));
        } catch (UnsupportedEncodingException e) {
          e.printStackTrace();
        }
   //封装类.post发送数据
   HttpUtil.post(CO2Activity.this, "control", entity, "application/json", new JsonHttpResponseHandler() {
    @Override
    public void onFailure(int statusCode, Header[] headers, Throwable throwable, JSONObject errorResponse) {
         super.onFailure(statusCode, headers, throwable, errorResponse);
      }

   @Override
   public void onSuccess(int statusCode, Header[] headers, JSONObject response) {
        super.onSuccess(statusCode, headers, response);
     }
 });
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java AsyncHttpClient 是一个基于非阻塞的、事件驱动的 HTTP 客户端库。它提供了简洁易用的 API,用于发送 HTTP 请求并处理响应。AsyncHttpClient 支持异步执行请求,并且可以处理大量的并发请求。它是基于 Netty 库实现的,具有高性能和可靠性。 使用 AsyncHttpClient,你可以创建一个客户端实例并发送各种类型的 HTTP 请求,例如 GET、POST、PUT、DELETE 等。你可以设置请求的 URL、请求头、请求体等,并指定回调函数来处理响应结果。 下面是一个使用 AsyncHttpClient 发送 GET 请求的示例代码: ```java import org.asynchttpclient.*; public class AsyncHttpClientExample { public static void main(String[] args) throws Exception { try (AsyncHttpClient asyncHttpClient = Dsl.asyncHttpClient()) { asyncHttpClient.prepareGet("http://example.com/") .execute(new AsyncCompletionHandler<Response>() { @Override public Response onCompleted(Response response) throws Exception { System.out.println(response.getResponseBody()); return response; } @Override public void onThrowable(Throwable t) { t.printStackTrace(); } }); } } } ``` 在上面的示例中,我们使用 `prepareGet` 方法创建一个 GET 请求,并指定了请求的 URL。然后,我们通过 `execute` 方法发送请求,并使用匿名内部类实现了 `AsyncCompletionHandler` 接口来处理响应结果。在 `onCompleted` 方法中,我们可以获取响应的内容并进行处理。 除了 GET 请求,AsyncHttpClient 还支持其他类型的请求,如 POST、PUT、DELETE 等。你可以根据实际需求选择合适的方法进行使用。 希望对你有帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值