engine方式封装OkHttp的异步GET

OkHttpEngine

首先,OkHttp是通过单例模式得到的。单例模式有一个私有的构造方法和一个静态的get方法。先看构造方法中做了什么。

    private OkHttpEngine(Context context) {
        File sdcache = context.getExternalCacheDir();
        int cacheSize = 10 * 1024 * 1024;
        OkHttpClient.Builder builder = new OkHttpClient.Builder()
                .connectTimeout(15, TimeUnit.SECONDS)
                .writeTimeout(20,TimeUnit.SECONDS)
                .readTimeout(20,TimeUnit.SECONDS)
                .cache(new Cache(sdcache.getAbsoluteFile(),cacheSize));
        mOkHttpClient = builder.build();
        mHandler = new Handler();
    }

主要做了两件事:

  • 通过创建者模式构造了OkHttpClient,设置了缓存地址,缓存大小等。
  • 新建了一个handler。

然后在getInstance方法中利用双重校验锁的方式得到单例。

    public static OkHttpEngine getInstance(Context context){
        if (mInstance == null){
            synchronized (OkHttpEngine.class){
                if (mInstance  == null){
                    mInstance = new OkHttpEngine(context);
                }
            }
        }
        return mInstance;
    }

然后发送异步请求:

    public void getAsynHttp(String url,ResultCallback callback){

        final Request request = new Request.Builder()
                .url(url)
                .build();
        Call call = mOkHttpClient.newCall(request);
        dealResult(call, callback);
    }

做了三件事情:

  1. 构建request。
  2. OkHttpClient根据request得到call。
  3. dealResult根据call和回调结果callback处理结果。
dealResult
   private void dealResult(Call call, final ResultCallback callback) {
        call.enqueue(new Callback() {
            @Override
            public void onFailure(Call call, IOException e) {
                sendFailedCallback(call.request(), e, callback);
            }

            @Override
            public void onResponse(Call call, Response response) throws IOException {
                sendSuccessCallback(response.body().string(), callback);
            }
        });
    }

call通过enqueue方法实现Callback异步,重写回调结果的onFailure和onResponse方法。最终调用了sendFailedCallback和sendSuccessCallback方法。

sendSuccesCallback
    private void sendSuccessCallback(final String str,final ResultCallback callback) {
        mHandler.post(new Runnable() {
            @Override
            public void run() {
                if (callback != null){
                    try {
                        callback.onResponse(str);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }
        });
    }

通过handler的post方法开启子线程发送请求。这里callback是抽象类,方法需要被重写。

然后在主线程中通过Engine的方式来发送请求。

    private void getAsynForEngine() {
        OkHttpEngine.getInstance(MainActivity.this).getAsynHttp(
            "http://www.baidu.com", new ResultCallback() {
                @Override
                public void onError(Request request, Exception e) {

                }

                @Override
                public void onResponse(String str) throws IOException {
                    Log.d(TAG, str);
                    Toast.makeText(getApplicationContext(),"请求成功",
                            Toast.LENGTH_SHORT).show();
                }
            });
    }

直接得到engine对象,调用getAsynHttp方法重写onError和onResponse方法即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值