在应用程序启动时,控制台会打印以下内容:
Firebase API initialization failure.
java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invoke(Native Method)
at com.google.firebase.FirebaseApp.zza(Unknown Source)
at com.google.firebase.FirebaseApp.initializeApp(Unknown Source)
//..
Caused by: java.lang.IllegalAccessError: Method 'void android.support.v4.content.ContextCompat.<init>()' is inaccessible to class 'com.google.firebase.iid.zzg'
Firebase 设置是按照说明完成的:
classpath 'com.google.gms:google-services:3.1.0'
被添加到顶层build.gradle
apply plugin: 'com.google.gms.google-services'
已添加到应用级别build.gradle
运行./gradlew app:dependencies
,我可以看到以下输出:
com.google.firebase:firebase-core:9.0.0
\--- com.google.firebase:firebase-analytics:9.0.0
+--- com.google.android.gms:play-services-basement:9.0.0
| \--- com.android.support:support-v4:23.0.0 -> 25.3.1 (*)
+--- com.google.firebase:firebase-common:9.0.0
| +--- com.google.android.gms:play-services-basement:9.0.0 (*)
| \--- com.google.android.gms:play-services-tasks:9.0.0
| \--- com.google.android.gms:play-services-basement:9.0.0 (*)
\--- com.google.firebase:firebase-analytics-impl:9.0.0
+--- com.google.android.gms:play-services-base:9.0.0
| +--- com.google.android.gms:play-services-basement:9.0.0 (*)
| +--- com.google.firebase:firebase-common:9.0.0 (*)
| \--- com.google.android.gms:play-services-tasks:9.0.0 (*)
+--- com.google.android.gms:play-services-basement:9.0.0 (*)
+--- com.google.firebase:firebase-iid:9.0.0
| +--- com.google.android.gms:play-services-basement:9.0.0 (*)
| \--- com.google.firebase:firebase-common:9.0.0 (*)
\--- com.google.firebase:firebase-common:9.0.0 (*)
也许这是问题的一部分,也许不是,但我觉得奇怪的是最新版本的插件包含旧版本的 Firebase ( 9.0.0
) 而不是11.0.1
.
此外,如错误所述,问题是由以下原因引起的:
java.lang.IllegalAccessError: Method 'void android.support.v4.content.ContextCompat.<init>()'
这似乎表明 v4 支持库可能与该问题有关。
是什么导致了这些问题,解决方案是什么?