RxEasyHttpネットワークライブラリカスタムデータ構造(7)
3718 ワード
githubソースの住所:https://github.com/zhou-you/RxEasyHttp
カスタムアプリResult
このライブラリでデフォルトで提供されているのは標準AppliResoultです.内部はAppliResultによって解析されています.データ構造がAppliResultと違って、あなたのプロジェクトでApplight Code()、getData()、getMsg()とisOk()を引き継いで、自分のニーズを実現します.このライブラリの中のAppliResultは以下の通りです.
カスタムアプリ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を見てください.