我有一个带有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)。
3条答案
按热度按时间qeeaahzv1#
终于自己解决了!贴在这里,让别人可能会觉得这个有用。
我将
multiDexEnabled
设置为true
,因此需要显式指定某些类,以便旧平台(SDK 19及更早版本)正确使用OpenTok。这意味着我必须在我的应用/build中包含
multiDexKeepProguard
。gradledefaultConfig
:在我的
multiDexKeepProguard
文件中(我的文件恰好是app
目录中名为proguard-rules.pro
的文本文件),我必须确保包含以下行:这使得我的OpenTok移动的应用程序可以通过SDK 27(Android 8.1奥利奥)在SDK 16(Android 4.1果冻豆)上正常工作。
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文件并使用它,您的错误将得到解决。
就是这样。
gz5pxeao3#
更新到OpenTok版本2.21.4,问题在android 12及以上版本中得到解决。