okhttp拦截器

//这样使用

public class OkUtil {


    public static OkUtil okUtil;
    private final OkHttpClient okHttpClient;

    //私有构造函数
    private OkUtil(){
        okHttpClient = new OkHttpClient.Builder()
                //log拦截器 ----------使用
              //  .addInterceptor(new LogInterceptor())
                .build();
    }

    //DCL模式
    public static OkUtil getInstance(){

        if(null == okUtil){
            synchronized (OkUtil.class){
                if(null == okUtil){
                    return new OkUtil();
                }
            }
        }

        return okUtil;
    }

    //
    public void get(String s, Callback callback){
        Request request = new Request.Builder().url(s).build();
       okHttpClient.newCall(request).enqueue(callback);

    }

}

//log
/______01

public class LogInterceptor implements Interceptor {
    @Override
    public Response intercept(Chain chain) throws IOException {
        Request request = chain.request();
        //请求之前
        //打印系统时间
        Log.d("LogInterceptor", "System.nanoTime():" + System.nanoTime());
        //打印头部信息
        Headers headers = request.headers();
        String type = headers.get("content-type");
        String cache = headers.get("cache-control");
        Log.d("LogInterceptor", type + "……" + cache);
        //请求之后
        Response response = chain.proceed(request);
        //打印系统时间
        Log.d("LogInterceptor", "System.nanoTime():" + System.nanoTime());
        return response;
    }
}

_______02

public class LogInterceptor implements Interceptor {
    @Override
    public Response intercept(Chain chain) throws IOException {
        Request request = chain.request();
        //打印所需信息
        logPrint(request);
        Response response = chain.proceed(request);
        //打印所需信息
        logPrint(request);
        return response;
    }

    private void logPrint(Request request) {
        Log.e("LogInterceptor", "request:" + request);
        Log.e("LogInterceptor", "System.nanoTime():" + System.nanoTime());
        Log.e("LogInterceptor", request.method());
    }
}

网络

public class RedirectInterceptor implements Interceptor {
    @Override
    public Response intercept(Chain chain) throws IOException {
        //1.Chain可以获取请求过程中的所有细节
        Request request = chain.request();
        //获取新请求
        Request newRequest = request.newBuilder()
                //将请求地址重新指向福利接口
                .url(Constant.BEAUTY_URL)
                .build();
        //将新请求挂载到请求队列上
        Response response = chain.proceed(newRequest);
        return response;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值