58同城 Android 客户端升级 ReactNative 到 0.64.x 调研

2024-03-18 11:50

本文主要是介绍58同城 Android 客户端升级 ReactNative 到 0.64.x 调研,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Target React Native version: v0.64.0-rc.2

WubaRN 版本已经两年没有升级了,现在已经更新很多新的工具,业务上期望能够支持。

  • 目标1:能提供升级 WubaRN SDK 到 0.64.x 版本,并提供 58同城测试包
  • 目标2:评估内部业务迁移成本

内容

  1. WubaRNSDK
  2. 测试bundle
  3. 58App
  4. 迁移成本

WubaRNSDK

1. build react native

由于 WubaRNSDK 是对 React Native 做的一层封装,从修复 bug 及修改或完善自定义功能等方面,WubaRNSDK 需对 ReactNative 源码进行部分修改,所以我们先要获取 0.64.x React Native 的 aar.

我们使用 react-native init 创建一个工程,指定 React Native 版本为 0.64.0-rc.2:

react-native init RN064Test --version 0.64.0-rc.2

创建完成后,切换到 RN064Test 目录,执行 npm install, 执行完成后,可以在 ../RN1064Test/node_modules/react-native/android/com/facebook/react/react-native/0.64.0-rc.2 获取到 react-native-0.64.0-rc.2.aar:

2. 修改 WubaRNSupportor 依赖

打开 WubaRNSDK,将 gradle.properties 中的 buildWubaRN 改成 true, 拷贝上面编译好的 react-native-0.64.0-rc.2.aar 到 /WubaRNSupportor/libs 目录,修改 WubaRNSupportor 的 build.gradle 依赖:

api(name: \'react-native-0.64.0-rc.2\', ext: \'aar\')

注意:react-native-0.64.0-rc.2 包含了 4 个 abi (armeabi-v7a、arm64-v8a、x86、x86_64),这边提供比较全的 abi 架构,由接入方去选择,所以我们删除之前 WubaRNSupportor/libs 下的 so


参考 .../RN1064Test/node_modules/react-native/ReactAndroid 修改 build.gradle 依赖:

dependencies {api fileTree(include: ['*.jar'], dir: 'libs')api "org.jetbrains.kotlin:kotlin-stdlib:$kotlinVersion"api("com.facebook.infer.annotation:infer-annotation:0.11.2")api("com.facebook.yoga:proguard-annotations:1.14.1")api("javax.inject:javax.inject:1")api 'org.aspectj:aspectjrt:1.8.13'api("androidx.appcompat:appcompat:1.0.0")api("androidx.swiperefreshlayout:swiperefreshlayout:1.0.0")api("com.facebook.fresco:fresco:1.10.0")api("com.facebook.fresco:imagepipeline-okhttp3:1.10.0")api("com.facebook.soloader:soloader:0.9.0")api("com.google.code.findbugs:jsr305:3.0.2")api("com.squareup.okhttp3:okhttp:3.12.12")api("com.squareup.okhttp3:okhttp-urlconnection:3.12.12")api("com.squareup.okio:okio:1.17.5")api("com.facebook.fbjni:fbjni-java-only:0.0.3")api "androidx.transition:transition:1.1.0"api(name: 'react-native-0.64.0-rc2', ext: 'aar')
}

3. 查看 WubaRNSupportor 切入点对应类及方法是否有变化

4. 修改 WubaRNPlugin 工程
插件工程,集合 WubaRN 需求进行的二次开发。剔除了 ReactNative 原始 aar 文件中的 x86 格式的 so 文件。配合 WubaRNSupportor 编译 WubaRN aar 文件

修改 WubaRNTransform.groovy 文件中 0.57.0.aar 为0.64.0-rc2.aar
修改插件版本为 1.1.1,然后执行 task 中 upload:uploadArchives 任务。

插件上传成功后,修改 RN SDK 根目录的 build.gradle:

classpath \'com.wuba.react:wubarn-plugin:1.1.1\'

5. 升级/添加第三方库 (移动到了 WubaRNSupportor 库中)

由于新版的 ReactNative 下掉了一些内置库,所以需要而外添加依赖 (注意一定要和 js 使用的版本一致):

https://github.com/react-native-webview/react-native-webview
https://github.com/react-native-netinfo/react-native-netinfo
https://github.com/th3rdwave/react-native-safe-area-context

同时需要升级,react-native-gesture-handler、react-native-reanimated (注意一定要和 js 使用的版本一致):

在 WubaRN.java 中注册 package:

private static void addThirdPartyPackages(@NonNull ReactInstanceManagerBuilder builder) {builder.addPackage(new RNCWebViewPackage()).addPackage(new NetInfoPackage()).addPackage(new RNGestureHandlerPackage()).addPackage(new ReanimatedPackage()).addPackage(new SafeAreaContextPackage());}

6. 修改 wubarn、wubarn-support、samples 报错代码

ModuleSpec 构造器被私有化,改成静态工厂方法:

旧的:

new ModuleSpec(new Provider<NativeModule>() {@Overridepublic NativeModule get() {return new XXXModule(reactApplicationContext);}
}, XXXModule.class.getName())

新的:

ModuleSpec.nativeModuleSpec(XXXModule.class.getName(), new Provider<NativeModule>() {@Overridepublic NativeModule get() {return new XXXModule(reactApplicationContext);}
})

7. 发布 WubaRNSupportor

参考 WubaRNSDK/WubaRNSupportor/README.md 发布 WubaRNSupportor, 将 buildWubaRN 改成 false.

发布时会存在类冲突,需要将 wubarn 中的 react-native-gesture-handler、react-native-reanimated 依赖先注释起来,同时注释掉报错代码,发布成功后还原注释。

dependencies {api fileTree(dir: \'libs\', include: [\'*.jar\'])testImplementation \'junit:junit:4.12\'api \'com.android.support:appcompat-v7:28.0.0\'api \'com.wuba.wuxian.lib:WubaRxDataSourcesLib:10010.6.1\'api \'com.wuba.wuxian.sdk:wubanetworklib:2.0.3\'api \'com.orhanobut:logger:2.1.1\'api \'com.google.code.gson:gson:2.8.1\'if (isBuildWubaRN) {api project(\':WubaRNSupportor\')} else {api "com.wuba.react:wubarn:${wubarnAspectPublishVersion}"}
}

8. 更新 jsc-android

将 .../RN1064Test/node_modules/jsc-android/ 中的 android-jsc-r245459.aar、android-jsc-intl-r245459.aar 中的 so 拷贝出来 (改成 .zip 解压),更新 wubarn 中的 libs:

9. 更新 core bundle

找 FE 提供基于 0.64.x 打包的 core bundle 文件,在 demo 和 接入 app 中做替换 (assets 目录)


10. 运行 WubaRNSDK Demo

运行 WubaRNSDK demo,加载 id 为 300 的 bundle, 热更新成功后,渲染 bundle 出现:

com.wuba.wbrn E/ReactNativeJS: React Native version mismatch.JavaScript version: 0.57.8Native version: 0.64.0-rc.2

这是因为 js bundle 与 WubaRNSDK 使用的 React Native 版本不一致导致的,为了看到效果,我们使用一个种子工程来测试
 

测试Bundle

运行 RN064Test 项目:

npm install
npm start

ERROR TypeError: undefined is not an object (evaluating \'ReactCurrentDispatcher$2.current\')

LOG  Running "Wuba" with {"rootTag":1}ERROR  TypeError: undefined is not an object (evaluating \'ReactCurrentDispatcher$2.current\')ERROR  Error: Should not already be working.

解决方案:

yarn upgrade
yarn upgrade --latest
yarn start

使用 WubaRNSDK demo 提供的本地调试功能,使用 debug 加载:

wbapp demo:

58App

发布 WubaRNSDK 3.3.18-rn-v064.x1,集成到 58App, 客户端主要是修改 WubaRNSDK 版本号,适配最新 API

编译问题 1:

Could not resolve org.webkit:android-jsc:r245459

将 WubaRNSDK 工程目录中的 jsc-android 文件夹拷贝到 58ClientProject 根目录,并在根目录的 build.gradle 中加入:

   maven {// Local Maven repo containing AARs with JSC library built for Androidurl "$rootDir/jsc-android/dist"}

编译问题 2:
fresco、soloader 等版本不一致,以 58App 的版本为准,在发布 WubaRNSupportor 库时修改这些版本号

迁移成本

注意:此处只涉及到 native 的迁移成本,不包括 FE 和 server

​​​​​​​

 

 

这篇关于58同城 Android 客户端升级 ReactNative 到 0.64.x 调研的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/822244

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

使用Java实现获取客户端IP地址

《使用Java实现获取客户端IP地址》这篇文章主要为大家详细介绍了如何使用Java实现获取客户端IP地址,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 首先是获取 IP,直接上代码import org.springframework.web.context.request.Requ

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Python手搓邮件发送客户端

《Python手搓邮件发送客户端》这篇文章主要为大家详细介绍了如何使用Python手搓邮件发送客户端,支持发送邮件,附件,定时发送以及个性化邮件正文,感兴趣的可以了解下... 目录1. 简介2.主要功能2.1.邮件发送功能2.2.个性签名功能2.3.定时发送功能2. 4.附件管理2.5.配置加载功能2.6.

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

SpringBoot实现websocket服务端及客户端的详细过程

《SpringBoot实现websocket服务端及客户端的详细过程》文章介绍了WebSocket通信过程、服务端和客户端的实现,以及可能遇到的问题及解决方案,感兴趣的朋友一起看看吧... 目录一、WebSocket通信过程二、服务端实现1.pom文件添加依赖2.启用Springboot对WebSocket