RetrofitUtils另一种封装

https://github.com/Ahrijin/AndroidWeek2

public class RetrofitUtils {
private MyApiService myApiService1;

private RetrofitUtils(){
    HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor();
    loggingInterceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
    OkHttpClient okHttpClient = new OkHttpClient.Builder()
            .readTimeout(20, TimeUnit.SECONDS)
            .connectTimeout(20, TimeUnit.SECONDS)
            .writeTimeout(20, TimeUnit.SECONDS)
            .addInterceptor(loggingInterceptor)
            .retryOnConnectionFailure(true)
            .build();
    Retrofit retrofit = new Retrofit.Builder()
            .addConverterFactory(GsonConverterFactory.create())
            .addCallAdapterFactory(RxJavaCallAdapterFactory.create())
            .baseUrl(Contacts.BASE_URL)
            .client(okHttpClient)
            .build();
    myApiService1 = retrofit.create(MyApiService.class);
}
public static RetrofitUtils getInstance() {
    return RetroHolder.retro;
}

private static class RetroHolder {
    private static final RetrofitUtils retro = new RetrofitUtils();
}

public void get(String url,Map<String,String> map,final HttpListener listener){
    Observer observer = new Observer<ResponseBody>() {
        @Override
        public void onCompleted() {
            Log.e("onCompleted","onCompleted");
        }
        //网络处理失败
        @Override
        public void onError(Throwable e) {
            Log.e("onError","onError"+e.getMessage());
            if (listener != null) {
                listener.onError(e.getMessage());
            }
        }
        //网络处理成功
        @Override
        public void onNext(ResponseBody responseBody) {
            Log.d("onNext","onNext");
            if (listener != null) {
                try {
                    listener.onSuccess(responseBody.string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

        }
    };
    myApiService1.get(url, map)
            .subscribeOn(Schedulers.io())//io就是子线程
            //在主线程调用
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(observer);
}

public void post(String url,Map<String,String> map,final HttpListener listener){
    Observer observer = new Observer<ResponseBody>() {
        @Override
        public void onCompleted() {
            Log.e("onCompleted","onCompleted");
        }
        //网络处理失败
        @Override
        public void onError(Throwable e) {
            Log.e("onError","onError"+e.getMessage());
            if (listener != null) {
                listener.onError(e.getMessage());
            }
        }
        //网络处理成功
        @Override
        public void onNext(ResponseBody responseBody) {
            Log.d("onNext","onNext");
            if (listener != null) {
                try {
                    listener.onSuccess(responseBody.string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

        }
    };
    myApiService1.post(url, map)
            .subscribeOn(Schedulers.io())//io就是子线程
            //在主线程调用
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(observer);
}

public void posts(String url,int userid,String sessionId, Map<String, Integer> map, final HttpListener listener) {
    Observer observer = new Observer<ResponseBody>() {
        @Override
        public void onCompleted() {
            Log.e("onCompleted", "onCompleted");
        }

        //网络处理失败
        @Override
        public void onError(Throwable e) {
            Log.e("onError", "onError" + e.getMessage());
            if (listener != null) {
                listener.onError(e.getMessage());
            }
        }

        //网络处理成功
        @Override
        public void onNext(ResponseBody responseBody) {
            Log.d("onNext", "onNext");
            if (listener != null) {
                try {
                    listener.onSuccess(responseBody.string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

        }
    };
    myApiService1.posts(url,userid,sessionId, map)
            .subscribeOn(Schedulers.io())//io就是子线程
            //在主线程调用
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(observer);
}

//取消点赞
public void del(String url,int userid,String sessionId, Map<String, Integer> map, final HttpListener listener) {
    Observer observer = new Observer<ResponseBody>() {
        @Override
        public void onCompleted() {
            Log.e("onCompleted", "onCompleted");
        }

        //网络处理失败
        @Override
        public void onError(Throwable e) {
            Log.e("onError", "onError" + e.getMessage());
            if (listener != null) {
                listener.onError(e.getMessage());
            }
        }

        //网络处理成功
        @Override
        public void onNext(ResponseBody responseBody) {
            Log.d("onNext", "onNext");
            if (listener != null) {
                try {
                    listener.onSuccess(responseBody.string());
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

        }
    };
    myApiService1.delete(url,userid,sessionId, map)
            .subscribeOn(Schedulers.io())//io就是子线程
            //在主线程调用
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(observer);
}

public interface HttpListener {
    void onSuccess(String jsonStr);

    void onError(String error);
}

}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值