在API级别低于21的情况下找不到com.google.firebase.provider.FirebaseInitProvider类

5

在API 19(Kitkat)中遇到了错误,但在API 23及以上版本中运行正常。我已经在Gradle文件和多 Dex 依赖中启用了 MultiDex,但仍然无法解决问题。请给出一个解决方案。代码如下:

              java.lang.RuntimeException: Unable to get provider com.google.firebase.provider.FirebaseInitProvider: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/system/framework/com.google.android.maps.jar", zip file "/data/app/com.trackawesome-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.trackawesome-2, /vendor/lib, /system/lib]]
                                                                    at android.app.ActivityThread.installProvider(ActivityThread.java:5011)
                                                                    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4582)
                                                                    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4522)
                                                                    at android.app.ActivityThread.access$1500(ActivityThread.java:151)
                                                                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1381)
                                                                    at android.os.Handler.dispatchMessage(Handler.java:110)
                                                                    at android.os.Looper.loop(Looper.java:193)
                                                                    at android.app.ActivityThread.main(ActivityThread.java:5292)
                                                                    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:824)
                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640)
                                                                    at dalvik.system.NativeStart.main(Native Method)
                                                                 Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/system/framework/com.google.android.maps.jar", zip file "/data/app/com.trackawesome-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.trackawesome-2, /vendor/lib, /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.ActivityThread.installProvider(ActivityThread.java:4996)
                                                                    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4582) 
                                                                    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4522) 
                                                                    at android.app.ActivityThread.access$1500(ActivityThread.java:151) 
                                                                    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1381) 
                                                                    at android.os.Handler.dispatchMessage(Handler.java:110) 
                                                                    at android.os.Looper.loop(Looper.java:193) 
                                                                    at android.app.ActivityThread.main(ActivityThread.java:5292) 
                                                                    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:824) 
                                                                    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640) 
                                                                    at dalvik.system.NativeStart.main(Native Method) 

这是我的gradle文件:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 24
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.trackawesome"
        minSdkVersion 15
        targetSdkVersion 24
        versionCode 1
        versionName "1.0"
        multiDexEnabled true
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:24.2.1'
    compile 'com.google.android.gms:play-services:10.2.1'
    compile 'com.squareup.retrofit:retrofit:1.9.0'
    compile 'com.android.support:recyclerview-v7:24.2.1'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.android.support:cardview-v7:24.2.1'
    compile 'com.android.support:multidex:1.0.1'
    testCompile 'junit:junit:4.12'

}

编译SDK版本为25,目标SDK版本也为25,使用v7:25.2.0代替v7:24.2.1。然后进行清理、重建和运行操作。 - IntelliJ Amiya
如果您遇到相同的问题,请告诉我。 - IntelliJ Amiya
相同的错误,没有任何改变。 - Navjot.jassal
尝试禁用即时运行并安装应用程序。 - Divyesh Patel
1
请阅读我的回答:https://dev59.com/h1wX5IYBdhLWcg3w2Sdr#33430306 - IntelliJ Amiya
1
@IntelliJ Amiya,谢谢你的回答,我已经检查并执行了它,它可以正常工作。 - Navjot.jassal
2个回答

4
你尝试在你的AndroidManifest.xml文件中添加Multidex应用程序类了吗?
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.myapp">
    <application
            android:name="android.support.multidex.MultiDexApplication" >
        ...
    </application>
</manifest>

请添加以下依赖项:
dependencies {
  compile 'com.android.support:multidex:1.0.1'
}

阅读此处以获取更多信息:使用Android Studio配置超过64K方法的应用程序


0
请在您的 build.gradle 文件中添加以下代码行。这将为我解决这个问题。
repositories 
{
    mavenCentral()
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接