美文网首页
React Native Android 设置自定义OkHttp

React Native Android 设置自定义OkHttp

作者: FreeVic | 来源:发表于2018-01-25 19:23 被阅读0次

背景

项目需要在React Native(之后简称RN)的网络请求中写入cookie数据给服务端校验,但是RN在0.42版本后不再支持用户自定义设置OkHttpClient,所以就需要换一种方式给RN的网络请求写入cookie。

我当前环境:

RN 0.51.0

Android 16及以上

RN当中fetch请求是在NetWorkingModule 这个类中的OkHttpClient发起的,所以我们需要替换成我们自己的client,大致有以下三种方案:

1.下载RN源码修改然后编译打包

(不推荐直接修改源码,如果RN版本更新那么维护起来就比较痛苦了)

Android端的源码其实就是node modules/react-native下ReactAndroid和ReactCommon两个项目,关于怎么导入到安卓工程,有很多文章:RN源码编译1 RN源码编译2

找到 NetWorkingModule 这个类的构造方法

/**

  * @param context the ReactContext of the application

  */

  public NetworkingModule(final ReactApplicationContext context) {

   原来 this(context, null, OkHttpClientProvider.createClient(), null);

   改为 this(context, null, OkHttpClientProvider.getOkHttpClient(), null);

  }

然后设置自定义的client OkHttpClientProvider.replaceOkHttpClient(client)

2.反射设置自定义的client

虽然NetWorkingModule 中的client是final的,但是并没有在声明的时候就进行初始化,所以通过反射是可以进行设值的,由于时间原因,并没有去实践这种做法。

3.实现自定义的 MainReactPackage

由于 NetWorkingModule 是在 MainReactPackage 中初始化的,而 MainReactPackage 又是我们自己设置给 ReactInstanceManager ,所以就可以尝试继承 MainReactPackage ,重写生成 NetWorkingModule 的逻辑。需要注意的是 NetWorkingModule 的访问是包范围的,所以初始化代码也要放在对应的包下面,即com.facebook.react.modules.network

public class MyMainReactPackage extends MainReactPackage {

   @Override

   public List getNativeModules(ReactApplicationContext context) {

       List nativeModules = super.getNativeModules(context);

       return adjustModules(context, nativeModules);

   }

   private List adjustModules(ReactApplicationContext context, List moduleSpecs) {

       ArrayList modules = new ArrayList<>(moduleSpecs);

       for (int i = 0; i < modules.size(); i++) {

           ModuleSpec spec = modules.get(i);

           if (spec.getType().equals(NetworkingModule.class)) {

               modules.set(i, getCustomNetworkingModule(context));

               break;

           }

       }

       return modules;

   }

   private ModuleSpec getCustomNetworkingModule(final ReactApplicationContext context) {

       return ModuleSpec.nativeModuleSpec(

               NetworkingModule.class,

               new Provider() {

                   @Override

                   public NativeModule get() {

                       return NetworkingModuleUtils.createNetworkingModuleWithCustomClient(context);

                   }

               });

   }

}

public class NetworkingModuleUtils {

   public static NetworkingModule createNetworkingModuleWithCustomClient(ReactApplicationContext context) {

       OkHttpClient client = OkHttpClientProvider.createClient();

       // ... full access to customize client

       return new NetworkingModule(context, null, OkHttpClientManager.getInstance().mOkHttpClient);

   }

}

方法1和方法3亲测可用,方法2只是一个思路,估计还会有坑,比如怎么获取 NetWorkingModule 的引用

相关文章

网友评论

      本文标题:React Native Android 设置自定义OkHttp

      本文链接:https://www.haomeiwen.com/subject/eeqpaxtx.html