转载请以链接形式标明出处: 本文出自:103style的博客
base on 3.12.0
目录
- 前言
LogInterceptor
实践addInterceptor
与addNetworkInterceptor
的区别
前言
前面我们在 RealCall.execute()流程介绍 和 okhttp之五个拦截器的介绍 中介绍了拦截器的执行顺序 和 每个自带拦截器的作用。
我们知道 我们自定义的拦截器会最先执行,在由响应结果之后也会最后处理。
没看过 RealCall.execute()流程介绍 和 okhttp之五个拦截器的介绍 的小伙伴可以先去看看。
官方关于拦截器的介绍 :戳我
LogInterceptor 实践
自定义拦截器主要的逻辑就是:
- 实现
Interceptor
接口,重写intercept(Interceptor.Chain chain)
方法 - 调用
Response response = chain.proceed(request);
传递给下一层拦截器获取他的返回结果。 如下:
/**
* @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转化,数据解密 等。
当然也可以获取Connection
和 Call
以及以下操作 :
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
配置拦截器:
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
带有请求的。
以上