Retrofit-OkHttp 动态切换服务器地址

需求:

一个app可能需要根据地区、用户等,动态设置不同的服务器地址,而okhttp为单例模式,不支持动态切换

方案:

利用okhttp的拦截器功能,实现该需求

1、利用headers参数,设置fixed标记的为地址固定不变接口,其他为动态切换(逻辑判断根据需求自己定义)

    @Headers({"domain:fixed"})//设置fixed为固定不变地址
    @GET("xx/xx/apiMethod")
    Observable<Result> apiMethod(@QueryMap Map<String, String> params);

2、编写动态切换地址的拦截器

public class BaseUrlInterceptor implements Interceptor {

    @Override
    public Response intercept(Chain chain) throws IOException {
        //获取request
        Request request = chain.request();
        //从request中获取原有的HttpUrl实例oldHttpUrl
        HttpUrl oldHttpUrl = request.url();

        List<String> headerValues = request.headers("domain");
        //获取request的创建者builder
        Request.Builder builder = request.newBuilder();
        //从request中获取headers,通过给定的键url_name
        //如果有这个header,先将配置的header删除,因此header仅用作app和okhttp之间使用
        builder.removeHeader("domain");
        //匹配获得新的BaseUrl

        int domainType = 0;// 0:动态 1:固定
        for (int i = 0; i < headerValues.size(); i++) {
            if (headerValues.get(i).equals("fixed")) {
                domainType = 1;
            }
        }

        //根据业务逻辑,动态获取的服务器地址
        String baseUrl = SharedPreferencesUtil.getString(MyApplication.getInstance(), "", "baseUrl", "");

        if (!TextUtils.isEmpty(baseUrl) && domainType == 0) {

            HttpUrl newBaseUrl = null;
            newBaseUrl = HttpUrl.parse(baseUrl);

            //重建新的HttpUrl,修改需要修改的url部分
            HttpUrl newFullUrl = oldHttpUrl
                    .newBuilder()
                    .scheme(newBaseUrl.scheme())
                    .host(newBaseUrl.host())//更换主机名
                    .port(newBaseUrl.port())//更换端口
                    .build();
            //重建这个request,通过builder.url(newFullUrl).build();
            // 然后返回一个response至此结束修改
            return chain.proceed(builder.url(newFullUrl).build());
        }
        return chain.proceed(chain.request());
    }
}

3、okhttp配置拦截器

        okBuilder = new OkHttpClient.Builder();

        ...

        okBuilder.addInterceptor(new BaseUrlInterceptor());//配置动态切换拦截器

        ...

        client = okBuilder.build();

        retrofit = new Retrofit.Builder()
                .baseUrl(HOST)
                .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
                .addConverterFactory(GsonConverterFactory.create())
                .client(client)
                .build();

如果您有其他需要,或者相关内容有什么不完善的地方,请留言给我!!

您也可以加入下方qq群,共同学习进步,感谢参与!!

Android学习交流群:523487222

点击链接加入群【Android学习群】

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于Retrofit、RxJava和OkHttp的封装,可以按以下步骤进行: 1. 导入依赖库:在你的项目中,首先需要导入Retrofit、RxJava和OkHttp的相关依赖库。 2. 创建Retrofit实例:使用Retrofit.Builder创建一个Retrofit实例,并指定服务器的基本URL、OkHttp客户端等配置信息。 ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl("http://your.base.url") .client(okHttpClient) // 使用自定义的OkHttpClient .addConverterFactory(GsonConverterFactory.create()) // 添加Gson转换器 .addCallAdapterFactory(RxJava2CallAdapterFactory.create()) // 添加RxJava适配器 .build(); ``` 3. 定义API接口:创建一个接口,声明你需要访问的API方法,使用注解来定义请求方法、路径和参数等信息。 ```java public interface ApiService { @GET("api/data/{category}/{count}") Observable<DataResponse> getData(@Path("category") String category, @Path("count") int count); } ``` 4. 创建API服务:使用Retrofit.create方法创建一个实现了API接口的服务实例。 ```java ApiService apiService = retrofit.create(ApiService.class); ``` 5. 发起网络请求:使用RxJava的Observable来发起网络请求,并处理返回的结果。 ```java apiService.getData("Android", 10) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(new Observer<DataResponse>() { @Override public void onSubscribe(Disposable d) { // 订阅时的操作 } @Override public void onNext(DataResponse dataResponse) { // 请求成功时的操作 } @Override public void onError(Throwable e) { // 请求出错时的操作 } @Override public void onComplete() { // 请求完成时的操作 } }); ``` 以上就是使用Retrofit、RxJava和OkHttp进行封装的基本步骤,当然你还可以根据具体需求进行更复杂的封装和处理。希望对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值