okhttp自定义配置:拦截器、缓存、cookie

拦截器:
可以再数据递交前后进行拦截。

@Test
    public void intercepter() {
        OkHttpClient okHttpClient = new OkHttpClient.Builder().addNetworkInterceptor(new Interceptor() {
            @NotNull
            @Override
            public Response intercept(@NotNull Chain chain) throws IOException {
                System.out.println(chain.request().header("version"));
                return chain.proceed(chain.request());
            }
        }).addInterceptor(new Interceptor() {
            @NotNull
            @Override
            public Response intercept(@NotNull Chain chain) throws IOException {
                //前置处理
                Request request = chain.request().newBuilder().addHeader("os", "android")
                        .addHeader("version", "1.0").build();
                Response response = chain.proceed(request);
                //后置处理
                return response;
            }
        }).build();

        Request request = new Request.Builder().url("https://www.httpbin.org/get?a=1&b=2").build();
        Call call = okHttpClient.newCall(request);
        try {
            Response response = call.execute();
            System.out.println(response.body().string());
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

上述代码可以在request中自动添加操作系统类型和版本号。
其中添加拦截有两种办法:addNetworkInterceptoraddInterceptor
后者优先执行,前者在后者之后执行。且同级拦截器依据代码顺序执行。

缓存:
存储发送过的请求,若后续请求相同,不需要重复发送,直接依据缓存从服务器取数据即可。

 OkHttpClient okHttpClient = new OkHttpClient.Builder()
                .cache(new Cache(new File("D:\\desktop\\"), 1024 * 1024));

缓存需要两个参数,一个存缓存文件,一个是存储大小。

Cookie:
用于网站对于连接进的用户进行状态识别:列入已登陆、Vip等身份辨别。

    Map<String, List<Cookie>> cookies = new HashMap<>();
OkHttpClient okHttpClient = new OkHttpClient.Builder()
                .cookieJar(new CookieJar() {
                    @Override
                    public void saveFromResponse(@NotNull HttpUrl httpUrl, @NotNull List<Cookie> list) {
                        cookies.clear();
                        cookies.put(httpUrl.host(), list);
                    }

                    @NotNull
                    @Override
                    public List<Cookie> loadForRequest(@NotNull HttpUrl httpUrl) {
                        List<Cookie> cookies = CookieTest.this.cookies.get(httpUrl.host());
                        return cookies == null ? new ArrayList<>() : cookies;
                    }
                })
                .build();

主要在okHttpClient 中添加cookie,记录状态后,后续才能继续进行例如登陆状态才能做的事情。
注意事项:
在cookie中两个方法:saveFromResponse保存连接后获取的cookie列表。loadForRequest当域名和我们登陆的相同时,才将对应服务器的cookie列表传出去,否则应该返回一个空列表(注意此处不能只返回null,会报错)。
全局的cookie需要用一个列表进行保存,因为一个域名对应一个cookie列表,可以用Map进行存储和取用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

魔幻音

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值