replaceOkHttpClient过时,改用setOkHttpClientFactory

标题同样可以起《React Native如何优雅的进行http请求》,要进行http请求免不了需要公共参数,token,cookie。但是如果在原生部分已经实现此功能了,在RN中需要再次实现就会比较麻烦,且会造成维护困难。所以需要网络请求如果能在Native层汇合,由Native层统一管理公共参数,token,cookie等等。会让RN的业务写起来非常方便。

通过关键词React Native custon okhttp能搜索到一些资料,比如0.43版本之前使用replaceOkHttpClient方法进行自定义,而在大于0.43版本就没有此方法了。改用setOkHttpClientFactory

class CustomNetworkModule implements OkHttpClientFactory {
    
    
    public OkHttpClient createNewNetworkModuleClient() {
    
    
        return new OkHttpClient.Builder()
                        .cookieJar(new ReactCookieJarContainer())
                        .build();
    }
}
  @Override
  public void onCreate() {
    
    
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
    // https://medium.com/@andr3wjack/stetho-with-react-native-87642e5d7131#.oc293ztbx
    OkHttpClient client = OkHttpClientProvider.getOkHttpClient()
            .newBuilder()
            .addNetworkInterceptor(new StethoInterceptor())
            .build();

    // 过时
    OkHttpClientProvider.replaceOkHttpClient(client);

    OkHttpClientFactory factory = new OkHttpClientFactory() {
    
    
      @Override
      public OkHttpClient createNewNetworkModuleClient() {
    
    
        return null;
      }
    };
    OkHttpClientProvider.setOkHttpClientFactory(factory);
  }

猜你喜欢

转载自blog.csdn.net/kangear/article/details/117877263