Ошибка инициализации Firebase, несмотря на инициализацию - PullRequest
0 голосов
/ 05 сентября 2018

Я пытаюсь настроить передачу сообщений Firebase в приложении для Android, и, насколько я понимаю, мне нужно запустить FirebaseApp.initializeApp(context), прежде чем я сделаю что-нибудь еще с классами Firebase. У меня проблема в том, что я запускаю initializeApp, прежде чем пытаться получить токен устройства с FirebaseInstanceId.getInstance().getInstanceId(), но firebase все еще выдает эту ошибку:

09-05 11:16:20.314 24640-24640/com.company.AppName E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.company.AppName, PID: 24640
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.company.AppName/com.company.AppName.MainActivity}: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.company.AppName. Make sure to call FirebaseApp.initializeApp(Context) first.
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2778)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
        at android.app.ActivityThread.-wrap11(Unknown Source:0)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
     Caused by: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.company.AppName. 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.iid.FirebaseInstanceId.getInstance(Unknown Source:1)
        at com.company.AppName.MainActivity.onCreate(MainActivity.java:48)
        at android.app.Activity.performCreate(Activity.java:7009)
        at android.app.Activity.performCreate(Activity.java:7000)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1214)

Вот код, который инициализирует firebase и выдает ошибку (в MainActivity.java onCreate):

FirebaseApp.initializeApp(this);
NativeApp
    .shared()
    .setContext(this)
    .setDeviceToken(FirebaseInstanceId.getInstance().getInstanceId().toString());

Если я закомментирую строку setDeviceToken, ошибка не выдается. Является ли initializeApp асинхронным? Руководство по установке Firebase для Android даже не упоминает initializeApp.

1 Ответ

0 голосов
/ 05 сентября 2018

Вам не нужно вызывать initializeApp, если вы выполнили интеграцию с Firebase, используя документированную процедуру . Если вы выполняете стандартную интеграцию, Firebase будет автоматически инициализироваться при запуске приложения. Подробнее об этом читайте в документации API для FirebaseApp .

Если вы не выполнили стандартную интеграцию, то вам нужно вызвать initializeApp в нужное время для вашего варианта использования.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...