Android第三方网络框架Android开发学习

02 | Android 项目笔记 Retrofit+RxJav

2018-08-18  本文已影响11人  itkluo88

打算在本项目中引入目前流行的Retrofit+RxJava网络框架,为了尽快从使用角度上手,以及适应大伙老工程调用习惯, 所以参考了好几篇大神的demo,封装成通用的post请求

  1. 在Application中初始化网络参数
private void initHttp() {
        HttpSet.setOutLog(true);
        // Retrofit+Rxjava网络请求框架的参数配置
        HttpSet.config(this)//配置请求主机地址
                .baseUrl(HttpSet.API_HOST = API_BASE_HOST)
                //.baseUrl(API_HOST)
                //配置全局请求头
                .globalHeaders(new HashMap<String, String>())
                //配置全局请求参数
                .globalParams(new HashMap<String, String>())
                //配置读取超时时间,单位秒
                .readTimeout(30)
                //配置写入超时时间,单位秒
                .writeTimeout(30)
                //配置连接超时时间,单位秒
                .connectTimeout(30)
                //配置请求失败重试次数
                .retryCount(3)
                //配置请求失败重试间隔时间,单位毫秒
                .retryDelayMillis(1000)
                //配置开启Gzip请求方式,需要服务器支持
//                .postGzipInterceptor()
                //配置应用级拦截器
                // .interceptor(new HttpLogInterceptor()
                //        .setLevel(HttpLogInterceptor.Level.BODY))
                // 打印全部日志
                .networkInterceptor(new HttpLogInterceptor()
                        .setLevel(HttpLogInterceptor.Level.BODY))
                //配置网络拦截器
//                .networkInterceptor(new NoCacheInterceptor())
                //配置主机证书验证
                .hostnameVerifier(new SSLUtil.UnSafeHostnameVerifier(API_BASE_HOST))
                //配置SSL证书验证
                .SSLSocketFactory(SSLUtil.getSslSocketFactory(null, null, null)).build();
    }

其中API_BASE_HOST为要配置的主机地址, 如"https://www.jianshu.com/"

2.有两种调用方式

2-1.传入要解析的实体类包装类, 返回相应的实体类

public void getTResult() {
        Map<String, String> maps = new HashMap<>();
        maps.put("seat_id", "1");

        ILoading ll = new ILoading(this);
        ll.setMessage("网络请求");
        // data 是 对象 , 泛型是 CommonObjResp<T>
        // data 是 数组 , 泛型是 CommonArrayResp<T>
        HttpRequestHelper.doPost(UrlEntity.GET_START_AD, maps, new RespCallback<CommonObjResp<AdEntity>>() {
            @Override
            public void onResponse(CommonObjResp<AdEntity> response, String requestPath) {
                if (response.isSuccess()) {
                    AdEntity resp = response.getData();
                    LogUtil.e(TAG, "#结果#--data " + resp);
                    tv_result.setText("#200结果data##" + resp);
                } else {
                    LogUtil.e(TAG, "#结果# " + response);
                    tv_result.setText("#结果#:" + response);
                }
            }

            @Override
            public void onError(ApiException ex, String requestPath) {
                LogUtil.e(TAG, ex.toString());
                Toast.makeText(MainActivity.this, ex.toString(), Toast.LENGTH_LONG).show();
                tv_result.setText("#error#: " + ex);
            }
        }, ll);
    }

传入4个参数: 请求的路径,参数,回调, 对话框接口。 对话框ILoading可不传

这种方式,不用自己解析,返回的结果就是解析好的实体

2-2. 返回json字符串

public void getStringResult() {
        Map<String, String> maps = new HashMap<String, String>();
        maps.put("seat_id", "1");

        ILoading ll = new ILoading(this);
        ll.setMessage("网络请求");
        HttpRequestHelper.doPost(UrlEntity.GET_START_AD, maps, stringRespCallback, ll);
    }

private StringRespCallback stringRespCallback = new StringRespCallback() {
@Override
public void onResponse(String response, String requestPath) {
switch (requestPath) {
case UrlEntity.GET_START_AD:
LogUtil.e(TAG, "#结果#:" + response);
tv_result.setText("#结果#--:" + response);
parseStringResp(response);
break;
default:
break;
}

    }

    @Override
    public void onError(ApiException ex, String requestPath) {
        LogUtil.e(TAG, ex.toString());
        Toast.makeText(MainActivity.this, ex.toString(), Toast.LENGTH_LONG).show();
        tv_result.setText("#error#: " + ex);
    }

};

private void parseStringResp(String resp) {
        try {
            long start = System.currentTimeMillis();
            AdObj obj = JsonManager.parseJson(resp, AdObj.class);
            long end = System.currentTimeMillis();
            LogUtil.e(TAG, "  ##解析耗时##" + (end - start) + "##毫秒##" + (end - start) / 1000 + "##秒##");
            if (obj != null) {
                if (obj.isSuccess()) {
                    if (obj.getData() != null) {

                    }
                } else {
                    Toast.makeText(MainActivity.this, obj.getMsg(), Toast.LENGTH_LONG).show();
                }
            }

        } catch (JsonSyntaxException e) {
            e.printStackTrace();
        }
    }

传入4个参数: 请求的路径,参数,回调, 对话框接口。 对话框ILoading可不传,回调StringRespCallback 继承RespCallback。

这种方式需自己解析json, 比较灵活。另外它有一个优点:在一个页面有多个请求的时候, 只要创建一个回调StringRespCallback , 通过返回的请求路径requestPath去区分。 目前老工程就是这种场景, 所以很快就能切换到本框架。

3.底层几个关键类

HttpRequestHelper 适应相应的业务需求,做的包装,最终调RetrofitClient

RetrofitClient请求实现

RespObserver 网络返回的结果首先经过这里,在这做处理和转发 , 这里最终会调请求传入的回调RespCallback

好了,这里只做简单的使用笔记,具体看源码

https://github.com/kluo88/RetrofitHelper

上一篇下一篇

猜你喜欢

热点阅读