我有一个使用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应用程序。
有人对此有解决方案吗?
答案 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