标题同样可以起《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);
}