前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >okhttp之自定义拦截器

okhttp之自定义拦截器

作者头像
103style
发布2022-12-19 13:42:51
1K0
发布2022-12-19 13:42:51
举报
文章被收录于专栏:Android开发经验分享

转载请以链接形式标明出处: 本文出自:103style的博客


base on 3.12.0


目录

  • 前言
  • LogInterceptor实践
  • addInterceptoraddNetworkInterceptor 的区别

前言

前面我们在 RealCall.execute()流程介绍okhttp之五个拦截器的介绍 中介绍了拦截器的执行顺序 和 每个自带拦截器的作用。

我们知道 我们自定义的拦截器会最先执行,在由响应结果之后也会最后处理。

没看过 RealCall.execute()流程介绍okhttp之五个拦截器的介绍 的小伙伴可以先去看看。

官方关于拦截器的介绍 :戳我


LogInterceptor 实践

自定义拦截器主要的逻辑就是:

  • 实现Interceptor接口,重写 intercept(Interceptor.Chain chain)方法
  • 调用 Response response = chain.proceed(request); 传递给下一层拦截器获取他的返回结果。 如下:
代码语言:javascript
复制
/**
 * @author https://github.com/103style
 * @date 2019/9/10 14:15
 */
public class LogInterceptor implements Interceptor {

    @Override
    public Response intercept(Interceptor.Chain chain) throws IOException {
        //此三行代码是每个自定义拦截器中必须的
        Request request = chain.request();
        Response response = chain.proceed(request);
        return response;
    }
}

intercept(...) 中的三行代码是每个自定义拦截器中必须的

通过这三行代码,我们可以获取到 请求 和 响应 的信息。然后根据具体的业务需求去做对应的操作,比如日志打印json转化数据解密 等。

当然也可以获取ConnectionCall以及以下操作 :

代码语言:javascript
复制
Connection connection();
Call call();
int connectTimeoutMillis();
Chain withConnectTimeout(int timeout, TimeUnit unit);
int readTimeoutMillis();
Chain withReadTimeout(int timeout, TimeUnit unit);
int writeTimeoutMillis();
Chain withWriteTimeout(int timeout, TimeUnit unit);

打印日志的示例代码如下:

代码语言:javascript
复制
/**
 * @author https://github.com/103style
 * @date 2019/9/10 14:15
 */
public class LogInterceptor implements Interceptor {

    private static final String TAG = "LogInterceptor";

    @Override
    public Response intercept(Interceptor.Chain chain) throws IOException {
        Request request = chain.request();

        long t1 = System.nanoTime();
        Log.d(TAG, "request = " + request.toString());
        
        Response response = chain.proceed(request);

        long t2 = System.nanoTime();
        //1e6d = 10的6的方
        Log.d(TAG, "time cost = " + (t2 - t1) / 1e6d + "ms \n response = " + response.toString());

        return response;
    }
}

然后通过 OkHttpClient配置拦截器:

代码语言:javascript
复制
client = new OkHttpClient.Builder()
        .addInterceptor(new LogInterceptor())
        .build();

or

代码语言:javascript
复制
client = new OkHttpClient.Builder()
        .addNetworkInterceptor(new LogInterceptor())
        .build();

两种方式主要的区别是 addInterceptor 是最先执行的拦截器, addNetworkInterceptor是在ConnectInterceptor之后执行的拦截器。 可以在 RealCall.execute()流程介绍 知道。

官方的解释

addInterceptor: 无需担心中间响应,例如重定向和重试。 即使从缓存提供HTTP响应,也总是被调用一次。 遵守应用程序的原始意图。不关心OkHttp注入的标头,例如If-None-Match。 允许短路而不是Chain.proceed()。 允许重试并多次调用Chain.proceed()addNetworkInterceptor: 能够对诸如重定向和重试之类的中间响应进行操作。 不会在读取缓存时调用。 观察数据,就像通过网络传输数据一样。 访问Connection带有请求的。


以上

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-09-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 目录
  • 前言
  • LogInterceptor 实践
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档