为了账号安全,请及时绑定邮箱和手机立即绑定

RxJava2 + Retrofit2 完全指南 之 动态Url/Path/Parameter/Header

标签:
Java

前言

因为有需求,才会有解决方案。本篇文章就是为了解决以下类似问题:

  • 统一为所有接口加上一个参数,如appType或则version

  • 统一为请求加上一个header

  • 请求path变更了,需要按照一定规则将path进行替换

实现

实现思路也是比较简单的,只需要自己实现一个Interceptor,然后加在其它Interceptor之前,具体代码如下:

/**
 * 自定义的拦截器
 * 1. 实现baseUrl的动态替换
 * 2. path的替换
 * 3. 增加parameter
 * 3. 增加header
 */final class HostSelectionInterceptor implements Interceptor {    @Override
    public okhttp3.Response intercept(Chain chain) throws IOException {        // 拿到请求
        Request request = chain.request();

        HttpUrl httpUrl = request.url();
        HttpUrl.Builder newUrlBuilder = httpUrl.newBuilder();        // 替换host
        String host = httpUrl.host();        // 这里是判断 当然真实情况不会这么简单
        if (httpUrl.host().equals("api.github.com")) {            // 只是为了在demo中显示消息提示
            sendMessage("\n\n替换url:www.baidu.com\n");
            host = "www.baidu.com";
        }        // 重新设置新的host
        newUrlBuilder.host(host);        // 替换path
        //List<String> pathSegments = httpUrl.pathSegments();
        // 这里是我已经知道了我是要移除第一个路径,所以我直接就移除了
        // 真实项目中,判断条件更加复杂
        newUrlBuilder.removePathSegment(0);        // 将index的segment替换为传入的值
        //newUrlBuilder.setPathSegment(index,segment);

        // 添加参数
        newUrlBuilder.addQueryParameter("version", "v1.3.1");        // 创建新的请求
        request = request.newBuilder()
                .url(newUrlBuilder.build())
                .header("NewHeader", "NewHeaderValue")
                .build();        // 只是为了在demo中显示消息提示
        sendMessage("\n\n新请求地址和参数:" + request.url().toString() + "\n");        return chain.proceed(request);
    }
}

使用:

retrofit = new Retrofit.Builder()
            .client(new OkHttpClient.Builder()
                    .addInterceptor(getHttpLoggingInterceptor())
                    .addInterceptor(hostSelectionInterceptor)//加入自定义的拦截器
                    .build())
            .baseUrl("https://api.github.com/")
            .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
            .build();

演示:

webp

演示



作者:FullScreenDev
链接:https://www.jianshu.com/p/a1be6f53c243


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
全栈工程师
手记
粉丝
229
获赞与收藏
1002

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消