无法实例化应用程序 androidx.multidex.MultiDexApplication:java.lang.ClassNotFoundException

Posted

技术标签:

【中文标题】无法实例化应用程序 androidx.multidex.MultiDexApplication:java.lang.ClassNotFoundException【英文标题】:Unable to instantiate application androidx.multidex.MultiDexApplication: java.lang.ClassNotFoundException 【发布时间】:2020-02-24 00:06:39 【问题描述】:

我有一个 Ionic 3 应用程序。从最近几天开始,该应用程序编译成功,但在设备中打开之前崩溃。在模拟器上,它工作正常。

发生此错误:

java.lang.RuntimeException: Unable to instantiate application androidx.multidex.MultiDexApplication: java.lang.ClassNotFoundException: Didn't find class "androidx.multidex.MultiDexApplication" on path: DexPathList[[zip file "/data/app/com.hip.app-_pUW6ZegoL_8FtN7BFysGw==/base.apk"],nativeLibraryDirectories=[/data/app/com.hip.app-_pUW6ZegoL_8FtN7BFysGw==/lib/arm64, /system/lib64]]
    at android.app.LoadedApk.makeApplication(LoadedApk.java:1073)
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5992)
    at android.app.ActivityThread.access$1200(ActivityThread.java:206)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1686)
    at android.os.Handler.dispatchMessage(Handler.java:106)
    at android.os.Looper.loop(Looper.java:201)
    at android.app.ActivityThread.main(ActivityThread.java:6882)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:873)
Caused by: java.lang.ClassNotFoundException: Didn't find class "androidx.multidex.MultiDexApplication" on path: DexPathList[[zip file "/data/app/com.hip.app-_pUW6ZegoL_8FtN7BFysGw==/base.apk"],nativeLibraryDirectories=[/data/app/com.hip.app-_pUW6ZegoL_8FtN7BFysGw==/lib/arm64, /system/lib64]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:171)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
    at android.app.AppComponentFactory.instantiateApplication(AppComponentFactory.java:50)
    at android.app.Instrumentation.newApplication(Instrumentation.java:1121)
    at android.app.LoadedApk.makeApplication(LoadedApk.java:1065)
    ... 9 more

我的项目.properties

target=android-28
android.library.reference.1=CordovaLib
android.library.reference.2=app
cordova.system.library.1=androidx.annotation:annotation:1.0.0
cordova.gradle.include.1=branch-cordova-sdk/app-rules.gradle
cordova.gradle.include.2=cordova-plugin-firebase-lib/app-build.gradle
cordova.system.library.2=com.google.android.gms:play-services-tagmanager:16.+
cordova.system.library.3=com.google.firebase:firebase-auth:18.+
cordova.system.library.4=com.google.firebase:firebase-core:17.+
cordova.system.library.5=com.google.firebase:firebase-messaging:19.+
cordova.system.library.6=com.google.firebase:firebase-config:18.+
cordova.system.library.7=com.google.firebase:firebase-perf:18.+

我的 build.gradle

buildscript 
    repositories 
        google()
        jcenter()
        maven  url 'https://maven.fabric.io/public'  // Fabrics Maven repository from cordova-plugin-firebase-lib


    

    dependencies 

        classpath 'com.android.tools.build:gradle:3.3.0'

        classpath 'com.google.gms:google-services:4.2.0' // google-services dependency from cordova-plugin-firebase-lib

        classpath 'io.fabric.tools:gradle:1.25.4' // fabric dependency from cordova-plugin-firebase-lib
    


allprojects 
    repositories 
        google()
        jcenter()
        google() // Google's Maven repository from cordova-plugin-firebase-lib
    

    project.ext 
      defaultBuildToolsVersion="28.0.3" 
      defaultMinSdkVersion=21 
      defaultTargetSdkVersion=28 
      defaultCompileSdkVersion=28 
    



(模块:app)app/build.gradle:


apply plugin: 'com.android.application'

buildscript 
    repositories 
        mavenCentral()
        google()
        jcenter()
    

    dependencies 
        classpath 'com.android.tools.build:gradle:3.3.0'
    


// Allow plugins to declare Maven dependencies via build-extras.gradle.
allprojects 
    repositories 
        mavenCentral()
        jcenter()
    


task wrapper(type: Wrapper) 
    gradleVersion = '4.10.3'


// Configuration properties. Set these via environment variables, build-extras.gradle, or gradle.properties.
// Refer to: http://www.gradle.org/docs/current/userguide/tutorial_this_and_that.html
ext 
    apply from: '../CordovaLib/cordova.gradle'

    // The value for android.compileSdkVersion.
    if (!project.hasProperty('cdvCompileSdkVersion')) 
        cdvCompileSdkVersion = null;
    
    // The value for android.buildToolsVersion.
    if (!project.hasProperty('cdvBuildToolsVersion')) 
        cdvBuildToolsVersion = null;
    
    // Sets the versionCode to the given value.
    if (!project.hasProperty('cdvVersionCode')) 
        cdvVersionCode = null
    
    // Sets the minSdkVersion to the given value.
    if (!project.hasProperty('cdvMinSdkVersion')) 
        cdvMinSdkVersion = null
    
    // Whether to build architecture-specific APKs.
    if (!project.hasProperty('cdvBuildMultipleApks')) 
        cdvBuildMultipleApks = null
    
    // Whether to append a 0 "abi digit" to versionCode when only a single APK is build
    if (!project.hasProperty('cdvVersionCodeForceAbiDigit')) 
        cdvVersionCodeForceAbiDigit = null
    
    // .properties files to use for release signing.
    if (!project.hasProperty('cdvReleaseSigningPropertiesFile')) 
        cdvReleaseSigningPropertiesFile = null
    
    // .properties files to use for debug signing.
    if (!project.hasProperty('cdvDebugSigningPropertiesFile')) 
        cdvDebugSigningPropertiesFile = null
    
    // Set by build.js script.
    if (!project.hasProperty('cdvBuildArch')) 
        cdvBuildArch = null
    

    // Plugin gradle extensions can append to this to have code run at the end.
    cdvPluginPostBuildExtras = []


// PLUGIN GRADLE EXTENSIONS START
apply from: "../branch-cordova-sdk/app-rules.gradle"
apply from: "../cordova-plugin-firebase-lib/app-build.gradle"
// PLUGIN GRADLE EXTENSIONS END

def hasBuildExtras1 = file('build-extras.gradle').exists()
if (hasBuildExtras1) 
    apply from: 'build-extras.gradle'


def hasBuildExtras2 = file('../build-extras.gradle').exists()
if (hasBuildExtras2) 
    apply from: '../build-extras.gradle'


// Set property defaults after extension .gradle files.
if (ext.cdvCompileSdkVersion == null) 
    ext.cdvCompileSdkVersion = privateHelpers.getProjectTarget()
    //ext.cdvCompileSdkVersion = project.ext.defaultCompileSdkVersion

if (ext.cdvBuildToolsVersion == null) 
    ext.cdvBuildToolsVersion = privateHelpers.findLatestInstalledBuildTools()
    //ext.cdvBuildToolsVersion = project.ext.defaultBuildToolsVersion

if (ext.cdvDebugSigningPropertiesFile == null && file('../debug-signing.properties').exists()) 
    ext.cdvDebugSigningPropertiesFile = '../debug-signing.properties'

if (ext.cdvReleaseSigningPropertiesFile == null && file('../release-signing.properties').exists()) 
    ext.cdvReleaseSigningPropertiesFile = '../release-signing.properties'


// Cast to appropriate types.
ext.cdvBuildMultipleApks = cdvBuildMultipleApks == null ? false : cdvBuildMultipleApks.toBoolean();
ext.cdvVersionCodeForceAbiDigit = cdvVersionCodeForceAbiDigit == null ? false : cdvVersionCodeForceAbiDigit.toBoolean();
ext.cdvMinSdkVersion = cdvMinSdkVersion == null ? defaultMinSdkVersion : Integer.parseInt('' + cdvMinSdkVersion)
ext.cdvVersionCode = cdvVersionCode == null ? null : Integer.parseInt('' + cdvVersionCode)

def computeBuildTargetName(debugBuild) 
    def ret = 'assemble'
    if (cdvBuildMultipleApks && cdvBuildArch) 
        def arch = cdvBuildArch == 'arm' ? 'armv7' : cdvBuildArch
        ret += '' + arch.toUpperCase().charAt(0) + arch.substring(1);
    
    return ret + (debugBuild ? 'Debug' : 'Release')


// Make cdvBuild a task that depends on the debug/arch-sepecific task.
task cdvBuildDebug
cdvBuildDebug.dependsOn 
    return computeBuildTargetName(true)


task cdvBuildRelease
cdvBuildRelease.dependsOn 
    return computeBuildTargetName(false)


task cdvPrintProps 
    doLast 
        println('cdvCompileSdkVersion=' + cdvCompileSdkVersion)
        println('cdvBuildToolsVersion=' + cdvBuildToolsVersion)
        println('cdvVersionCode=' + cdvVersionCode)
        println('cdvVersionCodeForceAbiDigit=' + cdvVersionCodeForceAbiDigit)
        println('cdvMinSdkVersion=' + cdvMinSdkVersion)
        println('cdvBuildMultipleApks=' + cdvBuildMultipleApks)
        println('cdvReleaseSigningPropertiesFile=' + cdvReleaseSigningPropertiesFile)
        println('cdvDebugSigningPropertiesFile=' + cdvDebugSigningPropertiesFile)
        println('cdvBuildArch=' + cdvBuildArch)
        println('computedVersionCode=' + android.defaultConfig.versionCode)
        android.productFlavors.each  flavor ->
            println('computed' + flavor.name.capitalize() + 'VersionCode=' + flavor.versionCode)
        
    


android 
    defaultConfig 

        multiDexEnabled true

        versionCode cdvVersionCode ?: new BigInteger("" + privateHelpers.extractIntFromManifest("versionCode"))
        applicationId privateHelpers.extractStringFromManifest("package")
      minSdkVersion 19

      if (cdvMinSdkVersion != null) 
            minSdkVersion cdvMinSdkVersion
        
    

    lintOptions 
      abortOnError false;
    

    compileSdkVersion cdvCompileSdkVersion
    buildToolsVersion cdvBuildToolsVersion

    // This code exists for Crosswalk and other Native APIs.
    // By default, we multiply the existing version code in the
    // Android Manifest by 10 and add a number for each architecture.
    // If you are not using Crosswalk or SQLite, you can
    // ignore this chunk of code, and your version codes will be respected.

    if (Boolean.valueOf(cdvBuildMultipleApks)) 
        flavorDimensions "default"

        productFlavors 
            armeabi 
                versionCode defaultConfig.versionCode*10 + 1
                ndk 
                    abiFilters = ["armeabi"]
                
            
            armv7 
                versionCode defaultConfig.versionCode*10 + 2
                ndk 
                    abiFilters = ["armeabi-v7a"]
                
            
            arm64 
                versionCode defaultConfig.versionCode*10 + 3
                ndk 
                    abiFilters = ["arm64-v8a"]
                
            
            x86 
                versionCode defaultConfig.versionCode*10 + 4
                ndk 
                    abiFilters = ["x86"]
                
            
            x86_64 
                versionCode defaultConfig.versionCode*10 + 5
                ndk 
                    abiFilters = ["x86_64"]
                
            
        
     else if (Boolean.valueOf(cdvVersionCodeForceAbiDigit)) 
        // This provides compatibility to the default logic for versionCode before cordova-android 5.2.0
        defaultConfig 
            versionCode defaultConfig.versionCode*10
        
    

    compileOptions 
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    

    if (cdvReleaseSigningPropertiesFile) 
        signingConfigs 
            release 
                // These must be set or Gradle will complain (even if they are overridden).
                keyAlias = ""
                keyPassword = "__unset" // And these must be set to non-empty in order to have the signing step added to the task graph.
                storeFile = null
                storePassword = "__unset"
            
        
        buildTypes 
            release 
                signingConfig signingConfigs.release
            
        
        addSigningProps(cdvReleaseSigningPropertiesFile, signingConfigs.release)
    

    if (cdvDebugSigningPropertiesFile) 
        addSigningProps(cdvDebugSigningPropertiesFile, signingConfigs.debug)
    


/*
 * WARNING: Cordova Lib and platform scripts do management inside of this code here,
 * if you are adding the dependencies manually, do so outside the comments, otherwise
 * the Cordova tools will overwrite them
 */


dependencies 
    implementation fileTree(dir: 'libs', include: '*.jar')
    // SUB-PROJECT DEPENDENCIES START
    implementation(project(path: ":CordovaLib"))
    implementation "androidx.annotation:annotation:1.0.0"
    implementation "com.google.android.gms:play-services-tagmanager:16.+"
    implementation "com.google.firebase:firebase-auth:18.+"
    implementation "com.google.firebase:firebase-core:17.+"
    implementation "com.google.firebase:firebase-messaging:19.+"
    implementation "com.google.firebase:firebase-config:18.+"
    implementation "com.google.firebase:firebase-perf:18.+"
    // SUB-PROJECT DEPENDENCIES END


def promptForReleaseKeyPassword() 
    if (!cdvReleaseSigningPropertiesFile) 
        return;
    
    if ('__unset'.equals(android.signingConfigs.release.storePassword)) 
        android.signingConfigs.release.storePassword = privateHelpers.promptForPassword('Enter key store password: ')
    
    if ('__unset'.equals(android.signingConfigs.release.keyPassword)) 
        android.signingConfigs.release.keyPassword = privateHelpers.promptForPassword('Enter key password: ');
    


gradle.taskGraph.whenReady  taskGraph ->
    taskGraph.getAllTasks().each()  task ->
      if(['validateReleaseSigning', 'validateSigningRelease', 'validateSigningArmv7Release', 'validateSigningX76Release'].contains(task.name)) 
         promptForReleaseKeyPassword()
      
    


def addSigningProps(propsFilePath, signingConfig) 
    def propsFile = file(propsFilePath)
    def props = new Properties()
    propsFile.withReader  reader ->
        props.load(reader)
    

    def storeFile = new File(props.get('key.store') ?: privateHelpers.ensureValueExists(propsFilePath, props, 'storeFile'))
    if (!storeFile.isAbsolute()) 
        storeFile = RelativePath.parse(true, storeFile.toString()).getFile(propsFile.getParentFile())
    
    if (!storeFile.exists()) 
        throw new FileNotFoundException('Keystore file does not exist: ' + storeFile.getAbsolutePath())
    
    signingConfig.keyAlias = props.get('key.alias') ?: privateHelpers.ensureValueExists(propsFilePath, props, 'keyAlias')
    signingConfig.keyPassword = props.get('keyPassword', props.get('key.alias.password', signingConfig.keyPassword))
    signingConfig.storeFile = storeFile
    signingConfig.storePassword = props.get('storePassword', props.get('key.store.password', signingConfig.storePassword))
    def storeType = props.get('storeType', props.get('key.store.type', ''))
    if (!storeType) 
        def filename = storeFile.getName().toLowerCase();
        if (filename.endsWith('.p12') || filename.endsWith('.pfx')) 
            storeType = 'pkcs12'
         else 
            storeType = signingConfig.storeType // "jks"
        
    
    signingConfig.storeType = storeType


for (def func : cdvPluginPostBuildExtras) 
    func()


// This can be defined within build-extras.gradle as:
//     ext.postBuildExtras =  ... code here ... 
if (hasProperty('postBuildExtras')) 
    postBuildExtras()


我正在使用命令行来创建和签署构建,但我也尝试过:

在 android studio 中打开并同步项目

清理项目

重建项目

【问题讨论】:

对 ionic 了解不多,但是你有 app 级别的 gradle 属性吗? build.gradle(模块:应用程序)? @HaiderSaleem 是的,我有应用级 build.gradle(模块:app)。我已经更新了同样的问题。 可能会有所帮助***.com/questions/26763702/… 我试过了,构建的 Gradle 版本很旧。我正在使用更高版本的构建 Gradle。另外,我正在使用jetpack 版本,即androidx。图书馆。 【参考方案1】:

我已通过从项目中删除 MultiDex 并将 minSdkVersion 升级到 21 解决了这个问题。

【讨论】:

这里有同样的问题。你能解释一下如何从项目中删除 MultiDex 吗?谢谢

以上是关于无法实例化应用程序 androidx.multidex.MultiDexApplication:java.lang.ClassNotFoundException的主要内容,如果未能解决你的问题,请参考以下文章

RuntimeException:无法实例化应用程序

无法实例化应用程序匕首android

无法在客户端应用程序中实例化服务

无法实例化活动组件信息错误

Android MVVM:无法实例化视图模型

无法实例化活动 ComponentInfo