RxEasyHttpネットワークライブラリカスタムデータ構造(7)

3718 ワード

githubソースの住所:https://github.com/zhou-you/RxEasyHttp
カスタムアプリResult
このライブラリでデフォルトで提供されているのは標準AppliResoultです.内部はAppliResultによって解析されています.データ構造がAppliResultと違って、あなたのプロジェクトでApplight Code()、getData()、getMsg()とisOk()を引き継いで、自分のニーズを実現します.このライブラリの中のAppliResultは以下の通りです.
public class ApiResult {
    private int code;
    private String msg;
    private T data;
    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }

    public boolean isOk() {//         
        return code == 0 ? true : false;
    }
}
jsonフォーマットは似ています
{
"code": 100010101,
"data":   ,
"msg": "    "
}
もしあなたのデータ構造がこのようなものであれば、
{
"error_code": 0,
"result":   ,
"reason": "    "
}
それならあなたのbasebeanはこのように書くことができます.
public class CustomApiResult extends ApiResult {
    String reason;
    int error_code;
    //int resultcode;
    T result;
    @Override
    public int getCode() {
        return error_code;
    }
    @Override
    public void setCode(int code) {
        error_code = code;
    }
    @Override
    public String getMsg() {
        return reason;
    }
    @Override
    public void setMsg(String msg) {
        reason = msg;
    }
    @Override
    public T getData() {
        return result;
    }
    @Override
    public void setData(T data) {
        result = data;
    }
   /* @Override
    public boolean isOk() {
        return error_code==200;//    0    ,   isOk()  。
    }*/
}
インターネットの要請はこのように書いてもいいです.
EasyHttp.get(url)
                .readTimeOut(30 * 1000)//       
                .writeTimeOut(30 * 1000)
                .connectTimeout(30 * 1000)
                //.cacheKey(this.getClass().getSimpleName()+"11")
                //.cacheMode(CacheMode.CACHEANDREMOTE)
                //.cacheMode(CacheMode.ONLYREMOTE)
                //.headers("","")//     
                //.params("name","  ")//    
                //.addInterceptor()
                //.addConverterFactory()
                //.addCookie()
                //.timeStamp(true)
                .baseUrl("http://apis.juhe.cn")
                .params("phone", "   ")
                .params("dtype", "json")
                .params("key", "5682c1f44a7f486e40f9720d6c97ffe4")
                .execute(new CallBackProxy, ResultBean>(new SimpleCallBack() {
                    @Override
                    public void onError(ApiException e) {
                        //    
                    }

                    @Override
                    public void onSuccess(ResultBean response) {
                        //    
                    }
                }) {
                });
このような書き方はちょっと長いと思いますが、CallBackProxyの泛型パラメータは毎回記入しなければなりません.その中でCustomaアプリResoultはAiResoultを継承しています.Customashはプロジェクトのbasebeanに相当します.実際のプロジェクトに対してbasebeanは固定されていますので、この方法を引き続きパッケージしてもいいです.
 public static  Subscription customExecute(CallBack callBack) {
        return execute(new CallBackProxy, T>(callBack) {
        });
    }
以上の改造を通じて、再度コールする時に直接CallBackを使って、CallBackProxyに関心を持たなくてもいいです.明らかに簡単です.具体的にコードgithub Demoを見てください.