在 API 21 及以下版本中无法获取 com.google.firebase.provider.FirebaseInitProvider 提供程序。

6

我在API 18上遇到了问题,而在API 21及以上版本却能正常工作。

在早期的Lollipop版本设备中出现错误,但在API 21及以上版本中应用程序成功运行:

 E/AndroidRuntime: FATAL EXCEPTION: main
                                                                           java.lang.RuntimeException: Unable to get provider com.google.firebase.provider.FirebaseInitProvider: android.content.res.Resources$NotFoundException: String resource ID #0x7f070150
                                                                               at android.app.ActivityThread.installProvider(ActivityThread.java:4882)
                                                                               at android.app.ActivityThread.installContentProviders(ActivityThread.java:4485)
                                                                               at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4425)
                                                                               at android.app.ActivityThread.access$1300(ActivityThread.java:141)
                                                                               at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316)
                                                                               at android.os.Handler.dispatchMessage(Handler.java:99)
                                                                               at android.os.Looper.loop(Looper.java:137)
                                                                               at android.app.ActivityThread.main(ActivityThread.java:5103)
                                                                               at java.lang.reflect.Method.invokeNative(Native Method)
                                                                               at java.lang.reflect.Method.invoke(Method.java:525)
                                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
                                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
                                                                               at dalvik.system.NativeStart.main(Native Method)
                                                                            Caused by: android.content.res.Resources$NotFoundException: String resource ID #0x7f070150
                                                                               at android.content.res.Resources.getText(Resources.java:239)
                                                                               at android.content.res.Resources.getString(Resources.java:325)
                                                                               at com.google.android.gms.common.internal.zzai.getString(Unknown Source)
                                                                               at com.google.firebase.FirebaseOptions.fromResource(Unknown Source)
                                                                               at com.google.firebase.FirebaseApp.zzeh(Unknown Source)
                                                                               at com.google.firebase.provider.FirebaseInitProvider.onCreate(Unknown Source)
                                                                               at android.content.ContentProvider.attachInfo(ContentProvider.java:1214)
                                                                               at android.content.ContentProvider.attachInfo(ContentProvider.java:1189)
                                                                               at com.google.firebase.provider.FirebaseInitProvider.attachInfo(Unknown Source)
                                                                               at android.app.ActivityThread.installProvider(ActivityThread.java:4879)
                                                                               at android.app.ActivityThread.installContentProviders(ActivityThread.java:4485) 
                                                                               at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4425) 
                                                                               at android.app.ActivityThread.access$1300(ActivityThread.java:141) 
                                                                               at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316) 
                                                                               at android.os.Handler.dispatchMessage(Handler.java:99) 
                                                                               at android.os.Looper.loop(Looper.java:137) 
                                                                               at android.app.ActivityThread.main(ActivityThread.java:5103) 
                                                                               at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                               at java.lang.reflect.Method.invoke(Method.java:525) 
                                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
                                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
                                                                               at dalvik.system.NativeStart.main(Native Method) 

请帮我..:-(

提前感谢。

我尝试了下面的链接并搜索了一下,但没有得到结果。 无法获取提供程序com.google.firebase.provider.FirebaseInitProvider

等待有人帮助 :-(

Gradle文件:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion '23.0.2'

    compileOptions.encoding = 'windows-1251'
    compileOptions.encoding = 'ISO-8859-1'

    defaultConfig {
        applicationId "com.ascovalve.calculators"
        minSdkVersion 14
        targetSdkVersion 22
        vectorDrawables.useSupportLibrary = true
        multiDexEnabled true
    }

    packagingOptions {
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/LICENSE-FIREBASE.txt'
        exclude 'META-INF/NOTICE'
    }

    buildTypes {
        release {
            minifyEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
        }
    }
    sourceSets { main { res.srcDirs = ['src/main/res', 'src/main/res/values-v21'] } }
    dexOptions {

        preDexLibraries = false
        incremental = true;
        javaMaxHeapSize "4g"  
    }
    useLibrary 'org.apache.http.legacy'
}

configurations {
    all*.exclude group: 'com.google.firebase', module: 'firebase-common'
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.google.code.gson:gson:2.2.3'
    compile 'com.android.support:support-v4:+'
    compile 'com.google.firebase:firebase-core:9.2.1'
    compile 'com.google.android.gms:play-services-location:9.2.1' 
   compile 'com.firebase:firebase-client-android:2.3.1'
    compile 'com.google.firebase:firebase-messaging:9.2.1'


    compile 'com.google.firebase:firebase-database:9.2.1'
    compile 'com.google.firebase:firebase-auth:9.2.1'
    compile 'com.android.support:appcompat-v7:23.0.0'
    compile 'com.android.support:design:+'
    compile 'com.android.support:multidex:1.0.1'
}
afterEvaluate {
    tasks.matching {
        it.name.startsWith('dex')
    }.each { dx ->
        if (dx.additionalParameters == null) {
            dx.additionalParameters = []
        }
        dx.additionalParameters += '--multi-dex'
        dx.additionalParameters += "--main-dex-list=$projectDir/multidex.keep".toString()
    }
}

apply plugin: 'com.google.gms.google-services'

我已经发布了日志错误,你需要 gradle 文件吗? 让我知道你需要什么来解决这个问题 :-(.... - Bhumit
我不确定,但我认为此问题的原因在于 configurations { all*.exclude group: 'com.google.firebase', module: 'firebase-common' } - Dmytro Rostopira
抱歉,我想不出来了。 - Dmytro Rostopira
@Garg,我只是将style.xml复制并粘贴到v11和v14中,问题在于不同版本使用了不同的样式。 - Bhumit
1
@Bhumit,感谢您的关注:)。我已经找到了另一个解决方案,并且它对我有效...如果需要的话,我可以在这里发布我的解决方案,以便将来帮助任何人。 - Garg
显示剩余7条评论
1个回答

0

我曾经遇到过类似的错误,通过删除另一个Android应用反编译后剩余的R.java文件来解决了这个问题。(是的,这个反编译是合法的!)

那个Android应用也使用了google-play-services作为库,因此它的R.java文件覆盖了我的应用资源中的R.java文件,使得运行时使用的资源ID无效,从而导致Firebase在尝试使用google-play-services时出现错误。


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