【问题标题】:java.lang.IllegalStateException: Default FirebaseApp is not initialized in this processjava.lang.IllegalStateException:默认 FirebaseApp 未在此过程中初始化
【发布时间】:2019-01-23 10:08:14
【问题描述】:

我创建了一个新项目并通过firebase的android studio工具添加了firebase。一切都按照指示做,但我在应用程序午餐时收到此错误。

Process: com.chitchat, PID: 20084
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.chitchat/com.chitchat.MainActivity}: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.chitchat. Make sure to call FirebaseApp.initializeApp(Context) first.
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2951)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3086)
    at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
    at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
    at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1816)
    at android.os.Handler.dispatchMessage(Handler.java:106)
    at android.os.Looper.loop(Looper.java:193)
    at android.app.ActivityThread.main(ActivityThread.java:6718)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:495)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
 Caused by: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.chitchat. Make sure to call FirebaseApp.initializeApp(Context) first.
    at com.google.firebase.FirebaseApp.getInstance(com.google.firebase:firebase-common@@16.0.1:219)
    at com.google.firebase.auth.FirebaseAuth.getInstance(Unknown Source:1)
    at com.chitchat.MainActivity.onCreate(MainActivity.java:22)
    at android.app.Activity.performCreate(Activity.java:7144)
    at android.app.Activity.performCreate(Activity.java:7135)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1272)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2931)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3086) 
    at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) 
    at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108) 
    at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1816) 
    at android.os.Handler.dispatchMessage(Handler.java:106) 
    at android.os.Looper.loop(Looper.java:193) 
    at android.app.ActivityThread.main(ActivityThread.java:6718) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:495) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 

MainActivity.java 是

public class MainActivity extends AppCompatActivity {

private FirebaseAuth mAuth;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);


    FirebaseApp.initializeApp(MainActivity.this);
    mAuth = FirebaseAuth.getInstance();
}

@Override
public void onStart() {
    super.onStart();
    // Check if user is signed in (non-null) and update UI accordingly.
    FirebaseUser currentUser = mAuth.getCurrentUser();
    //updateUI(currentUser);

    if(currentUser == null){
        Intent startAct = new Intent(MainActivity.this, Start_Activity.class);
        startActivity(startAct);
        finish();
    }
}
}

而 gradle.build 是

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

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.chitchat"
        minSdkVersion 23
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support:design:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    implementation 'com.google.firebase:firebase-auth:16.0.3'
    implementation 'com.google.firebase:firebase-core:16.0.3'
    //implementation 'com.google.android.gms:play-services-base'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'


}

项目级 gradle.build

    buildscript {
    repositories {
        google()
        jcenter()

    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0'
        classpath 'com.google.gms:google-services:4.1.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()

    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

在网上找不到任何东西!添加了firebaseApp.initializeApp(this),它在任何指令中都不存在,但在模拟器和设备上仍然存在相同的错误。

【问题讨论】:

  • 是否有可能是我的 firebase 配置错误导致了这个错误!?

标签: java android firebase illegalstateexception


【解决方案1】:

我也遇到过这个问题。最近几周我看到很多人都遇到过这个问题。有问题

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

改成

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

如上所述here

因为根据这个讨论here,AGP 遇到了一些问题! 我认为这将解决您的问题。

编辑:截至 2021 年 1 月 30 日,只需更改为所有 firebase 类依赖项的最新版本,它应该可以工作:classpath 'com.google.gms:google-services:4.3.4'

【讨论】:

  • 我已将 google-services 更新到 4.3.9 并遇到了问题。降级到 4.3.4 解决了这个问题。
【解决方案2】:

将此添加到build.gradle 的底部:

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

【讨论】:

  • 发布您的项目级build.gradle
  • @AjayChoudhary 试试这个:FirebaseApp.initializeApp(getApplicationContext())
  • 试过这个 FirebaseApp.initializeApp(getApplicationContext()) :不走运!
  • 更新了项目级 build.gradle
【解决方案3】:

首先您需要在根级别 build.gradle 添加 com.google.gms:google-services:x.x.x。 像这样

buildscript {
repositories {
    jcenter()
}
dependencies {
    classpath 'com.android.tools.build:gradle:2.3.1'
    classpath 'com.google.gms:google-services:3.0.0'

    // NOTE: Do not place your application dependencies here; they belong
    // in the individual module build.gradle files
}

然后在你的 build.gradle(app) 底部添加谷歌插件。

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support:design:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    implementation 'com.google.firebase:firebase-auth:16.0.3'
    implementation 'com.google.firebase:firebase-core:16.0.3'
    //implementation 'com.google.android.gms:play-services-base'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'


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

【讨论】:

  • 'com.google.gms:google-services:4.1.0' 已经存在。我添加了“应用插件”,但这没有帮助。同样的错误!
【解决方案4】:

在您的 Application 类中添加以下代码而不是 Activity,以便将 Firebase 初始化为整个应用程序,而不仅仅是一个 Activity

@Override
public void onCreate() {
    super.onCreate();
    FirebaseApp.initializeApp(this);
}

另外,您需要将应用插件代码从 top 移动到 bottom 参考:Add Firebase SDK

// ADD THIS AT THE BOTTOM
apply plugin: 'com.google.gms.google-services'

它要求apply plugin: 'com.google.gms.google-services' 行位于app/build.gradle 文件的底部,这样就不会引入依赖冲突。您可以通过运行 ./gradlew :app:dependencies 查看此步骤的结果。 Reference

另外,请尝试将所有 firebase 和 gms:google-services 依赖项同步到最新版本。

【讨论】:

  • 我创建了一个新的java类,扩展了Application。在清单文件中创建条目。在其中使用了您的代码。仍然得到同样的错误!如果我误解了什么,请告诉我!
  • 对于那些使用 kotlin DSL 的人,请参阅answer
猜你喜欢
  • 2021-01-30
  • 2020-08-16
  • 1970-01-01
  • 2017-10-25
  • 2019-07-05
  • 2019-08-18
  • 1970-01-01
  • 1970-01-01
  • 2019-02-06
相关资源
最近更新 更多