React Native OpenTok无法在旧版Android上运行(可能缺少org/webrtc/voiceengine/BuildInfo.class)

nbysray5  于 2023-02-05  发布在  React
关注(0)|答案(3)|浏览(117)

我有一个带有OpenTok视图的React原生Android应用程序(作为原生模块编写)。我遇到了一个崩溃问题(在尝试示例化OpenTok视图时立即出现),影响了旧版Android(SDK 16-19,Jelly Bean到KitKat),任何OpenTok会话。最近的Android手机都没有问题;OpenTok工作完美。
以下是相关的Android logcat输出:

11-12 16:30:12.993 2949-2949/com.myapp I/OpenTokUnifiedView: APIKEY Connect Session
11-12 16:30:13.003 2949-2949/com.myapp I/OpenTokUnifiedView: apiKey: ********** sessionId: ********** token: **********
11-12 16:30:13.023 2949-2949/com.myapp I/dalvikvm: threadid=1: recursive native library load attempt (/data/app-lib/com.myapp-1/libopentok.so)
11-12 16:30:13.033 2949-2949/com.myapp I/dalvikvm: threadid=1: recursive native library load attempt (/data/app-lib/com.myapp-1/libopentok.so)
11-12 16:30:13.033 2949-2949/com.myapp I/dalvikvm: threadid=1: recursive native library load attempt (/data/app-lib/com.myapp-1/libopentok.so)
11-12 16:30:13.033 2949-2949/com.myapp I/dalvikvm: threadid=1: recursive native library load attempt (/data/app-lib/com.myapp-1/libopentok.so)
11-12 16:30:13.033 2949-2949/com.myapp I/dalvikvm: threadid=1: recursive native library load attempt (/data/app-lib/com.myapp-1/libopentok.so)
11-12 16:30:13.053 2949-2949/com.myapp E/BluetoothAdapter: Bluetooth binder is null
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: java.lang.NoClassDefFoundError: org/webrtc/voiceengine/BuildInfo
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.opentok.android.Session.init(Native Method)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.opentok.android.Session.<init>(Session.java:710)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.opentok.android.Session$Builder.build(Session.java:588)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.myapp.OpenTokUnifiedView.connectSession(OpenTokUnifiedView.java:114)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.myapp.OpenTokUnifiedView.setApiKey(OpenTokUnifiedView.java:72)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.myapp.OpenTokUnifiedViewManager.setApiKey(OpenTokUnifiedViewManager.java:34)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.reflect.Method.invokeNative(Native Method)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.reflect.Method.invoke(Method.java:515)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.ViewManagersPropertyCache$PropSetter.updateViewProp(ViewManagersPropertyCache.java:83)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.ViewManagerPropertyUpdater$FallbackViewManagerSetter.setProperty(ViewManagerPropertyUpdater.java:129)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.ViewManagerPropertyUpdater.updateProps(ViewManagerPropertyUpdater.java:48)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.ViewManager.updateProperties(ViewManager.java:34)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.NativeViewHierarchyManager.createView(NativeViewHierarchyManager.java:227)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.UIViewOperationQueue$CreateViewOperation.execute(UIViewOperationQueue.java:153)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.UIViewOperationQueue$1.run(UIViewOperationQueue.java:809)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.UIViewOperationQueue.flushPendingBatches(UIViewOperationQueue.java:922)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.UIViewOperationQueue.access$2100(UIViewOperationQueue.java:47)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.UIViewOperationQueue$DispatchUIFrameCallback.doFrameGuarded(UIViewOperationQueue.java:982)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.uimanager.GuardedFrameCallback.doFrame(GuardedFrameCallback.java:31)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.modules.core.ReactChoreographer$ReactChoreographerDispatcher.doFrame(ReactChoreographer.java:136)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.facebook.react.modules.core.ChoreographerCompat$FrameCallback$1.doFrame(ChoreographerCompat.java:107)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.view.Choreographer$CallbackRecord.run(Choreographer.java:759)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.view.Choreographer.doCallbacks(Choreographer.java:574)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.view.Choreographer.doFrame(Choreographer.java:543)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:747)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.os.Handler.handleCallback(Handler.java:733)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.os.Handler.dispatchMessage(Handler.java:95)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.os.Looper.loop(Looper.java:136)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at android.app.ActivityThread.main(ActivityThread.java:5017)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.reflect.Method.invokeNative(Native Method)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.reflect.Method.invoke(Method.java:515)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at dalvik.system.NativeStart.main(Native Method)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: Caused by: java.lang.ClassNotFoundException: Didn't find class "org.webrtc.voiceengine.BuildInfo" on path: DexPathList[[zip file "/data/app/com.myapp-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.myapp-1, /vendor/lib, /system/lib]]
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
11-12 16:30:13.063 2949-2949/com.myapp W/System.err: ... 34 more
11-12 16:30:13.063 2949-2949/com.myapp E/rtc: #
# Fatal error in ../../webrtc/modules/utility/source/helpers_android.cc, line 68
# last system error: 2
# Check failed: !jni->ExceptionCheck()
# Error during FindClass: org/webrtc/voiceengine/BuildInfo
#
11-12 16:30:13.063 2949-2949/com.myapp A/libc: Fatal signal 6 (SIGABRT) at 0x00000b85 (code=-6), thread 2949 (ale.app.staging)

由于看起来缺少org/webrtc/voiceengine/BuildInfo.class,我手动添加了audio_device_java. jar作为库(根据https://groups.google.com/forum/#!topic/discuss-webrtc/PkfAVr_TYQs上的建议),以查看它是否修复了这个问题。
然而,当我尝试构建时,OpenTok SDK似乎已经有了它,所以手动添加audio_device_java. jar没有帮助:

:app:transformClassesWithJarMergingForDebug FAILED

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':app:transformClassesWithJarMergingForDebug'.
> com.android.build.api.transform.TransformException: java.util.zip.ZipException: duplicate entry: org/webrtc/voiceengine/BuildInfo.class

不知道为什么旧版Android上的应用程序缺少org/webrtc/voiceengine/BuildInfo.class。旧版Android上可能发生了什么?
编辑:我发现这实际上对棒棒糖有效--修改了这个问题,以反映这个问题影响到SDK 19(KitKat)。

qeeaahzv

qeeaahzv1#

终于自己解决了!贴在这里,让别人可能会觉得这个有用。
我将multiDexEnabled设置为true,因此需要显式指定某些类,以便旧平台(SDK 19及更早版本)正确使用OpenTok。
这意味着我必须在我的应用/build中包含multiDexKeepProguard。gradle defaultConfig

defaultConfig {
    ...
    multiDexEnabled true
    multiDexKeepProguard file('proguard-rules.pro')
    ...
}

在我的multiDexKeepProguard文件中(我的文件恰好是app目录中名为proguard-rules.pro的文本文件),我必须确保包含以下行:

# Keep the following for OpenTok
-keep class com.opentok.** { *; }
-keep class org.webrtc.** { *; }

这使得我的OpenTok移动的应用程序可以通过SDK 27(Android 8.1奥利奥)在SDK 16(Android 4.1果冻豆)上正常工作。

rur96b6h

rur96b6h2#

我通过添加webrtc jar文件到android项目解决了这个问题
1.从https://drive.google.com/open?id=1bElH-Krh56cO2S8Biyp0LSFurjcxFIcT下载libjingle_peerconnection_java.jar文件
1.将其放入库/文件夹
1.运行应用程序
如果你得到了"多个dex文件定义android Logging. class"然后按照以下步骤
1.解压缩. jar文件
1.从文件夹(org. webrtc)中删除日志记录类文件
1.最后压缩为. jar文件并使用它,您的错误将得到解决。
就是这样。

gz5pxeao

gz5pxeao3#

更新到OpenTok版本2.21.4,问题在android 12及以上版本中得到解决。

相关问题