okhttp之自定义拦截器

转载请以链接形式标明出处:
本文出自: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); 传递给下一层拦截器获取他的返回结果。
    如下:
/**
 * @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以及以下操作 :

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);

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

/**
 * @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

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带有请求的。


以上

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OkHttp是一个用于处理HTTP请求的开源Java库。它提供了一个拦截器机制,可以在发送请求和接收响应之前对它们进行修改和处理。以下是关于OkHttp拦截器的一些介绍和示例: 1. OkHttp拦截器是一个接口,它有一个方法intercept(Chain chain),该方法接收一个Chain对象作为参数,该对象表示当前的拦截器链。 2. 拦截器链是按照添加顺序执行的,每个拦截器都可以选择将请求传递给下一个拦截器或者直接返回响应。 3. 拦截器可以在请求和响应中添加、修改或删除头信息,也可以重试请求或者记录请求和响应的日志等。 以下是一个简单的OkHttp拦截器示例,它会在请求头中添加一个自定义的User-Agent信息: ```java public class UserAgentInterceptor implements Interceptor { private static final String USER_AGENT_HEADER = "User-Agent"; private final String userAgent; public UserAgentInterceptor(String userAgent) { this.userAgent = userAgent; } @Override public Response intercept(Chain chain) throws IOException { Request request = chain.request(); Request newRequest = request.newBuilder() .header(USER_AGENT_HEADER, userAgent) .build(); return chain.proceed(newRequest); } } ``` 在上面的示例中,我们创建了一个名为UserAgentInterceptor的拦截器,它接收一个User-Agent字符串作为参数。在intercept方法中,我们首先获取当前的请求对象,然后使用Request.Builder添加一个自定义的User-Agent头信息,最后使用chain.proceed方法将请求传递给下一个拦截器或者返回响应。 以下是一个使用上面定义的拦截器的示例: ```java OkHttpClient client = new OkHttpClient.Builder() .addInterceptor(new UserAgentInterceptor("MyApp/1.0")) .build(); ``` 在上面的示例中,我们创建了一个OkHttpClient对象,并使用addInterceptor方法添加了一个UserAgentInterceptor拦截器。这样,在发送请求时,OkHttp会自动调用我们定义的拦截器,并在请求头中添加一个自定义的User-Agent信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值