Android 4.4(Kitkat)上的Ionic3 MainActivity ClassNotFoundException

时间:2019-03-21 04:20:17

标签: android cordova ionic3

我有一个使用Ionic 3和Cordova-Android 6.4.0的应用程序。该应用在Android API级别> 19(Kitkat)上可以正常运行。但是在Android 4.4上运行该应用程序会导致该应用程序在启动时崩溃,但出现以下异常:

03-21 14:07:40.513 2408-2408/com.xxx.app.xxx E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.xxx.app.xxx, PID: 2408
    java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.xxx.app.xxx/com.xxx.app.xxx.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "com.xxx.app.xxx.MainActivity" on path: DexPathList[[zip file "/data/app/com.xxx.app.xxx-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.xxx.app.xxx-2, /system/lib]]
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2121)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
        at android.app.ActivityThread.access$800(ActivityThread.java:135)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:136)
        at android.app.ActivityThread.main(ActivityThread.java:5017)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:515)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
        at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.xxx.app.xxx.MainActivity" on path: DexPathList[[zip file "/data/app/com.xxx.app.xxx-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.xxx.app.xxx-2, /system/lib]]
        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
        at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 
        at android.app.ActivityThread.access$800(ActivityThread.java:135) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
        at android.os.Handler.dispatchMessage(Handler.java:102) 
        at android.os.Looper.loop(Looper.java:136) 
        at android.app.ActivityThread.main(ActivityThread.java:5017) 
        at java.lang.reflect.Method.invokeNative(Native Method) 
        at java.lang.reflect.Method.invoke(Method.java:515) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
        at dalvik.system.NativeStart.main(Native Method) 

我已经了解了multidex修复程序,但是由于无法更改生成的Java代码以添加MultiDex.install(this);,因此无法将其应用于我的Ionic应用程序。

有人对此有解决方案吗?

1 个答案:

答案 0 :(得分:0)

here中描述了问题和解决方案。

function kebabToSnake(str) { var idNum = str.length; for(var i = 0; i <= idNum; i++) { var nStr = str.replace("-", "_"); } return nStr; } 来自于该应用程序及其库超过65,536个方法的事实,因此Java类分布在应用程序APK中的多个DEX文件(Dalvik EXecutable)中,即类。 dex,classes2.dex等。启动应用程序所需的Java类可能最终出现在应用程序APK中的classes2.dex中(而不是classes.dex),Dalvik运行时无法在Android版本低于5的应用程序中加载该类在Android网站上:

  

为multidex应用程序构建每个DEX文件时,构建工具执行复杂的决策,以确定主DEX文件中需要哪些类,以便您的应用程序可以成功启动。如果主DEX文件中未提供启动过程中所需的任何类,则您的应用程序将崩溃,并出现错误java.lang.NoClassDefFoundError。

解决方案是按照文本开头的链接中的描述,在文本文件中标识应用程序启动时引用的每个类。

但是,所需类的列表很长且很难建立。我已经了解了以下类,但是还有更多的启动类可以发现。我的解决方案是说“对不起,此应用仅适用于Android 5及更高版本。”

java.lang.ClassNotFoundException