1.FinalHttp是什么 :FinalHttp 对 HttpClient再次封装,最简洁的就是增加了许多回调的方法,对Get 和 Post 请求进行了简化。另外一点就是FinalHttp加入线程池操作,默认的Http请求池连接为3。下面是为FinalHttp可配置的操作。

1
2
3
4
5
6
7
8
FinalHttp finalHttp = new FinalHttp();
finalHttp.addHeader("Accept-Charset", "UTF-8");//配置http请求头
finalHttp.configCharset("UTF-8");
finalHttp.configCookieStore(null);
finalHttp.configRequestExecutionRetryCount(3);//请求错误重试次数
finalHttp.configSSLSocketFactory(null);
finalHttp.configTimeout(5000);//超时时间
finalHttp.configUserAgent("Mozilla/5.0");//配置客户端信息
 

2.FinalHttp 之 Get

1
2
3
4
5
6
7
8
9
10
11
12
13
14
//------------------get 请求-----------------------
 public void get( String url, AjaxCallBack<? extends Object> callBack) {
     get( url, null, callBack);
 }
  
 public void get( String url, AjaxParams params, AjaxCallBack<? extends Object> callBack) {
     sendRequest(httpClient, httpContext, new HttpGet(getUrlWithQueryString(url, params)), null, callBack);
 }
   
 public void get( String url, Header[] headers, AjaxParams params, AjaxCallBack<? extends Object> callBack) {
     HttpUriRequest request = new HttpGet(getUrlWithQueryString(url, params));
     if(headers != null) request.setHeaders(headers);
     sendRequest(httpClient, httpContext, request, null, callBack);
 }
 

三个方法的却别在于:第二个增加了参数。第三个增加了http header。,此处,AjaxParams 是一个 map集合。来看看 sendRequest方法。

1
2
3
4
5
6
7
8
9
protected <T> void sendRequest(DefaultHttpClient client, HttpContext httpContext, HttpUriRequest uriRequest, String contentType, AjaxCallBack<T> ajaxCallBack) {
       if(contentType != null) {
           uriRequest.addHeader("Content-Type", contentType);
       }
  
       new HttpHandler<T>(client, httpContext, ajaxCallBack,charset)
       .executeOnExecutor(executor, uriRequest);
  
   }
 

这里面 直接调用了一个类HttpHandler的executeOnExecutor方法,传入了一个重要的参数executor。看看这个类:HttpHandler

1
2
3
4
5
6
7
8
9
10
11
12
public class  HttpHandler  <T> extends  AsyncTask<Object, Object, Object> implements EntityCallBack{
  
        private final AjaxCallBack<T> callback;
          
        private int executionCount = 0;
  
        public HttpHandler(AbstractHttpClient client, HttpContext context, AjaxCallBack<T> callback,String charset) {
                this.client = client;
                this.context = context;
                this.callback = callback;
                this.charset = charset;
        }
 

这个类继承了 AsyncTask,这个 AsyncTask是作者 自定义的,它相对于android 自带的 AsyncTask:修改了线程池属性,让并发线程按顺序执行。之前好像有人提到使用 afinal 加载图片是一个一个加载的,原因可能就在这里了。
这个类还实现了自定义的一个接口,里面的这个方法是我们回调的方法:

1
2
3
public interface EntityCallBack {
        public void callBack(long count,long current,boolean mustNoticeUI);
}
 

这表明了HttpHandler 是一个异步加载类,我精简掉方法中暂时不用的代码,很显然,他的异步方法应该在 这个方法中执行doInBackground:

1
2
3
4
5
6
7
8
9
10
11
12
13
@Override
        protected Object doInBackground(Object... params) {
                
                try {
                        publishProgress(UPDATE_START); // 开始
                        makeRequestWithRetries((HttpUriRequest)params[0]);//调用
                          
                } catch (IOException e) {
                        publishProgress(UPDATE_FAILURE,e,0,e.getMessage()); // 结束
                }
  
                return null;
        }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
private void makeRequestWithRetries(HttpUriRequest request) throws IOException {
                  
                boolean retry = true;
                IOException cause = null;
                HttpRequestRetryHandler retryHandler = client.getHttpRequestRetryHandler();
                while (retry) {
                        try {
                                if (!isCancelled()) {
                                        [color=Red]HttpResponse response = client.execute(request, context);[/color]//这里就开始执行了
                                        if (!isCancelled()) {
                                                handleResponse(response);
                                        }
                                }
                                return;
                        } catch (UnknownHostException e) {
                                publishProgress(UPDATE_FAILURE,e,0,"unknownHostException:can't resolve host");
                                return;
                        } catch (IOException e) {
                                cause = e;
                                retry = retryHandler.retryRequest(cause, ++executionCount,context);
                        } catch (NullPointerException e) {
                                cause = new IOException("NPE in HttpClient" + e.getMessage());
                                retry = retryHandler.retryRequest(cause, ++executionCount,context);
                        }catch (Exception e) {
                                cause = new IOException("Exception" + e.getMessage());
                                retry = retryHandler.retryRequest(cause, ++executionCount,context);
                        }
                }
                if(cause!=null)
                        throw cause;
                else
                        throw new IOException("未知网络错误");
        }

HttpResponse response = client.execute(request, context);这就开始执行了。
retry = retryHandler.retryRequest(cause, ++executionCount,context);这里出现异常执行一次,次数加一次。直到你设置的次数超过为止,retryHandler 就会直接返回false 中断 while(retry)

http://www.kwstu.com/ArticleView/419895180_2013925101126966

教程] 《开源框架-Afinal》之FinalHttp 01一步一脚的更多相关文章

  1. Android开源框架Afinal第一篇——揭开圣女的面纱

    Android开源框架Afinal第一篇——揭开圣女的面纱 分类: Android开源框架哪点事2013-09-02 14:25 260人阅读 评论(0) 收藏 举报 Afinal 这是Afinal在 ...

  2. 【开源项目3】Android快速开源框架--afinal

    Afinal简介 Afinal 是一个android的sqlite orm 和 ioc 框架.同时封装了android中的http框架,使其更加简单易用: 使用finalBitmap,无需考虑bitm ...

  3. Afinal开源框架中FinalActivity的使用

    1. 首先将afinal.jar文件复制到项目中的libs文件夹下 2. 让MainActivity不在继承系统的Activity,而是继承FinalActivity public class Mai ...

  4. Farseer.net轻量级ORM开源框架 V1.x 教程目录

    本篇教程将以Ver 1.x版本进行详细使用讲解 大家有任何疑问可以加入我们的官方QQ群进行讨论.QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net 整个 ...

  5. 开源框架】Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发

    [原][开源框架]Android之史上最全最简单最有用的第三方开源库收集整理,有助于快速开发,欢迎各位... 时间 2015-01-05 10:08:18 我是程序猿,我为自己代言 原文  http: ...

  6. 各种Android UI开源框架 开源库

    各种Android UI开源框架 开源库 转 https://blog.csdn.net/zhangdi_gdk2016/article/details/84643668 自己总结的Android开源 ...

  7. Pyhton开源框架(加强版)

    info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ...

  8. Python开源框架

    info:更多Django信息url:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC) ...

  9. 六款值得推荐的android(安卓)开源框架简介

    1.volley 项目地址 https://github.com/smanikandan14/Volley-demo (1)  JSON,图像等的异步下载: (2)  网络请求的排序(scheduli ...

随机推荐

  1. Tomcat通过Redis实现session共享的完整部署记录

    对于生产环境有了一定规模的tomcat集群业务来说,要实现session会话共享,比较稳妥的方式就是使用数据库持久化session.为什么要持久化session(共享session)呢?因为在客户端每 ...

  2. windows平台下编辑的内容传到linux平台出现中文乱码的解决办法

    现象说明:在windows下编辑的内容,上传到linux平台下出现中文乱码.如下: 在windows平台编写haha.txt文件,内容如下: 上传到linux平台,出现中文乱码,如下: 基本上面出现的 ...

  3. 在Mac终端显示 Git 当前所在分支

    1.进入你的home目录 cd ~ 2.编辑.bashrc文件 vi .bashrc 3.将下面的代码加入到文件的最后处 function git_branch { branch="`git ...

  4. LINUX第三次实践:程序破解

    LINUX第三次实践:程序破解 标签(空格分隔): 20135328陈都 一.掌握NOP.JNE.JE.JMP.CMP汇编指令的机器码 NOP:NOP指令即"空指令".执行到NOP ...

  5. 安装tesserocr错误(未解决)

    在win10下使用pip install tesserocr安装时,始终报错,未解决问题 解压tesserocr-2.2.2.tar.gz该文件夹后,查看setup.py文件,发现似乎model只能再 ...

  6. jeecg的下拉列表

    jeecg里面下拉列表的使用 ①建立数据字典seo_id <t:dictSelect field="operationPromotionAccount" typeGroupC ...

  7. 小学四则运算APP 第二阶段冲刺-第五天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第二次冲刺阶段时间:11.29~12.09 本次发布的是判断题代码,已经实现部分功能,,但是美中不足的是判断错误 panduanset.j ...

  8. java中for循环的几种方式

    比如定义一个数组int a[]={1, 2, 3, 4},下面我们罗列一下遍历这个数组的方法 1 for(;;) 这也是最常用的方法,不多做解释.代码如下 int a[] = {1, 2, 3, 4} ...

  9. node基础 npm、module、exports、require

    module 模块.包:可以认为是一个代码包,package,提供特定的功能(暴露给外界接口,让外界调用) exports 输出.导出:导出模块中的各种类型的变量,以及各种方法,导出之后,才可以被外界 ...

  10. [wiki]陶德曼调停

    陶德曼调停[编辑] 维基百科,自由的百科全书 凯申物流差点和谈 目录 1背景 2调停经过 3评价 4参见 背景[编辑] 主条目:中德合作 (1911年-1941年) 1936年11月25日,德国与日本 ...