【问题标题】:Make sure to call FirebaseApp.initializeApp(Context) first确保首先调用 FirebaseApp.initializeApp(Context)
【发布时间】:2017-12-19 13:15:13
【问题描述】:

其他问题可能已经完全一样了,但我真的不知道这里出了什么问题。提前感谢您的帮助。

build.gradle(项目)

        // Top-level build file where you can add configuration options common to all sub-projects/modules.

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

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

allprojects {
    repositories {
        jcenter()
        maven {
            url "https://maven.google.com" // Google's Maven repository
        }
    }
}

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

build.gradle(模块)

    apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.3"
    defaultConfig {
        applicationId "com.bustracker.usc.myapplication"
        minSdkVersion 21
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    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:25.3.1'
    compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha7'
    compile 'com.google.android.gms:play-services-maps:10.2.6'
    compile 'com.google.android.gms:play-services-location:10.2.6'
    compile 'com.google.firebase:firebase-database:10.2.6'
    testCompile 'junit:junit:4.12'
}

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

MainActivity.java

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        FirebaseApp.initializeApp(this);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);

        firebaseDatabase = FirebaseDatabase.getInstance();
        mRootReference = firebaseDatabase.getReference();
        mheadingReference = mRootReference.child("users");

错误:

FATAL EXCEPTION: main
                                                 Process: com.bustracker.sample.myapplication, PID: 2658
                                                 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.bustracker.sample.myapplication/com.bustracker.sample.myapplication.MainActivity}: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.bustracker.sample.myapplication. Make sure to call FirebaseApp.initializeApp(Context) first.
                                                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2665)
                                                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726)
                                                     at android.app.ActivityThread.-wrap12(ActivityThread.java)
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1477)
                                                     at android.os.Handler.dispatchMessage(Handler.java:102)
                                                     at android.os.Looper.loop(Looper.java:154)
                                                     at android.app.ActivityThread.main(ActivityThread.java:6119)
                                                     at java.lang.reflect.Method.invoke(Native Method)
                                                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
                                                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
                                                  Caused by: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.bustracker.sample.myapplication. Make sure to call FirebaseApp.initializeApp(Context) first.
                                                     at com.google.firebase.FirebaseApp.getInstance(Unknown Source)
                                                     at com.google.firebase.database.FirebaseDatabase.getInstance(Unknown Source)
                                                     at com.bustracker.sample.myapplication.MainActivity.onCreate(MainActivity.java:53)
                                                     at android.app.Activity.performCreate(Activity.java:6679)
                                                     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
                                                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2618)
                                                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726) 
                                                     at android.app.ActivityThread.-wrap12(ActivityThread.java) 
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1477) 
                                                     at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                     at android.os.Looper.loop(Looper.java:154) 
                                                     at android.app.ActivityThread.main(ActivityThread.java:6119) 
                                                     at java.lang.reflect.Method.invoke(Native Method) 
                                                     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) 
                                                     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776) 

其他问题可能已经完全一样了,但我真的不知道这里出了什么问题。提前感谢您的帮助。

【问题讨论】:

  • 是否有任何错误,然后分享您的错误。
  • @Dharmishtha,编辑详细信息以显示错误。谢谢

标签: java android firebase firebase-realtime-database


【解决方案1】:

对我来说,任何地方给出的解决方案都不起作用。只有这行得通。 只需将我的谷歌服务从 4.1.0 下载到 4.0.0

dependencies {
    classpath 'com.android.tools.build:gradle:3.3.0-alpha08'
    classpath 'com.google.gms:google-services:4.0.0'
    /*classpath 'com.google.gms:google-services:4.1.0' <-- this was the problem */
}

因此,如果您更新了 google 服务,只需尝试降级或更改为旧版本即可。 希望对其他人有所帮助。

【讨论】:

  • 这个临时变通办法成功了! 4.2.0 和 4.1.0 版本都导致相同的错误。 4.0.0 版效果很好。除非访问其他 Firebase 项目,否则不需要调用 FirebaseApp.initializeApp()!
  • android studio 中的 Firebase 插件自动生成的 gradle 依赖配置会导致这个问题,这有点令人失望。这种解决方法似乎是我在搜索解决它后发现的最简单(也是唯一)的方法。
  • 4.2.0 为我解决了这个问题
【解决方案2】:

根据文档:

如文档中所述:

任何 FirebaseApp 初始化都只能在应用的主进程中进行。不支持在主进程以外的进程中使用 Firebase,这可能会导致与资源争用相关的问题。

你需要在活动中初始化它。

在清单示例中添加一个应用程序类:

      <applicaton
       android:name="MyApplication"
       

然后这样做:

public class MyApplication extends Application {
  @Override
public void onCreate() {
    super.onCreate();
   FirebaseApp.initializeApp(this);
}

并从活动中删除初始化。您需要在作为基类的应用程序类中对其进行初始化。

编辑(关于应用程序):

用于维护全局应用程序状态的基类。您可以通过创建一个子类并将该子类的完全限定名称指定为 AndroidManifest.xml 标记中的“android:name”属性来提供自己的实现。 Application 类或 Application 类的子类在创建应用程序/包的进程时在任何其他类之前实例化。

有用的链接:https://developer.android.com/reference/android/app/Application.html

【讨论】:

  • 这是否意味着我应该在这个类中保存/检索数据的代码?
  • 不,这意味着您需要在应用程序的基类中初始化firebase。您可以正常检索并保存在活动中。您没有像答案中所说的那样在活动中对其进行初始化..还有这个非常古老的firebase(不确定您为什么要使用它..)
  • MyApplication 类有什么用?当我使用 firebaseDatabase 参考时,我该怎么称呼它?
  • 不,MyApplication 不是一个活动......你不要在任何地方调用它,它的类将扩展基类 Application 并且必须在基类中初始化 firebase,而不是每个活动..
  • 检查编辑可能有助于了解更多。您仍然需要像往常一样在活动中检索和保存数据,仅在应用程序的基类中完成初始化
【解决方案3】:

对我来说,确保 google-services 插件在我的 app.gradle 中初始化就足够了:

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

然后我什至根本不用打电话给FirebaseApp.initializeApp(Context)。也许它可以帮助某人。

【讨论】:

    【解决方案4】:

    我不知道为什么这对我有用,但删除了

    tools:node="replace" 
    

    来自我的 AndroidManifest.xml 将崩溃从马上改善到其他一些事情。希望我对某人有所帮助。

    【讨论】:

    • 请修正最后一行的语法,“from right away to from some other things”没有意义。
    猜你喜欢
    • 2020-02-04
    • 2018-02-09
    • 2019-08-23
    • 2021-04-16
    • 2019-01-06
    • 1970-01-01
    • 2021-10-13
    相关资源
    最近更新 更多