Приложение Firebase аварийно завершало работу при запуске, когда оно было активизировано в фоновом режиме

У меня есть Firebase, интегрированный в мое быстрое приложение. Вся инициализация выполняется программно, и FirebaseApp.config() вызывается самым первым в didLaunchWithOptions в AppDelegate.

Но по какой-то случайной причине, всякий раз, когда приложение находится в фоновом режиме в течение длительного времени, приложение просто падает во время работы, то есть делает его активным. Интересно, что этот сбой происходит ровно 2 раза в следующем потоке:

1. The App is idle in background
2. You bring it to the active mode(You just tap the icon to open the app. All this while the app isn't killed)
3. Tap 1  ---- The App Crashes----
4. Tap 2  ---- The App Crashes----
5. Tap 3  ---- The App Runs Normally ----

Я пытался устранить неполадки, но все мои усилия пропали даром. Я попытался настроить как раскадровки, так и программный запуск приложения. Ничего не работает.

Ниже приведена трассировка стека:

            SpotMi-Dev[74741:2958059] *** Terminating app due to uncaught exception 'FIRAppNotConfigured', reason: 'Failed to get default Firebase Database instance. Must call `[FIRApp configure]` (`FirebaseApp.configure()` in Swift) before using Firebase Database.'
        *** First throw call stack:
        (
        0   CoreFoundation                      0x000000010d3816fb __exceptionPreprocess + 331
        1   libobjc.A.dylib                     0x000000010c14aac5 objc_exception_throw + 48
        2   CoreFoundation                      0x000000010d381555 +[NSException raise:format:] + 197
        3   SpotMi-Dev                          0x0000000101be5ba1 +[FIRDatabase database] + 97
        4   SpotMi-Dev                          0x0000000101aaba6b $s10SpotMi_Dev13FBDataserviceCACycfc + 59
        5   SpotMi-Dev                          0x0000000101aac193 $s10SpotMi_Dev13FBDataserviceCACycfcTo + 19
        6   SpotMi-Dev                          0x0000000101aa696c $s10SpotMi_Dev13FBDataserviceCACycfC + 44
        7   SpotMi-Dev                          0x0000000101aa692c globalinit_33_8263DB418F9D5BC81149F56895386F46_func0 + 28
        8   libdispatch.dylib                   0x000000010ecaddb5 _dispatch_client_callout + 8
        9   libdispatch.dylib                   0x000000010ecaf83d _dispatch_once_callout + 66
        10  libswiftCore.dylib                  0x000000010e2c6579 swift_once + 25
        11  SpotMi-Dev                          0x0000000101aa69f4 $s10SpotMi_Dev13FBDataserviceC2dsACvau + 36
        12  SpotMi-Dev                          0x000000010180b013 $s10SpotMi_Dev9ProfileVCC18initializeUserPostyyF + 179
        13  SpotMi-Dev                          0x0000000101809278 $s10SpotMi_Dev9ProfileVCC11viewDidLoadyyF + 616
        14  SpotMi-Dev                          0x00000001018095b4 $s10SpotMi_Dev9ProfileVCC11viewDidLoadyyFTo + 36
        15  UIKitCore                           0x000000011589443b -[UIViewController loadViewIfRequired] + 1183
        16  UIKitCore                           0x0000000115894868 -[UIViewController view] + 27
        17  UIKitCore                           0x0000000115ebd4ad -[UIApplication(StateRestoration) _restoreApplicationPreservationStateWithSessionIdentifier:beginHandler:completionHandler:] + 6413
        18  UIKitCore                           0x0000000115eb8fdc -[UIApplication(StateRestoration) _doRestorationIfNecessary] + 211
        19  UIKitCore                           0x0000000115e8e2c9 -[UIApplication _handleDelegateCallbacksWithOptions:isSuspended:restoreState:] + 208
        20  UIKitCore                           0x0000000115e8fcad -[UIApplication _callInitializationDelegatesForMainScene:transitionContext:] + 3932
        21  UIKitCore                           0x0000000115e950c6 -[UIApplication _runWithMainScene:transitionContext:completion:] + 1617
        22  UIKitCore                           0x00000001156da6d6 __111-[__UICanvasLifecycleMonitor_Compatability _scheduleFirstCommitForScene:transition:firstActivation:completion:]_block_invoke + 904
        23  UIKitCore                           0x00000001156e2fce +[_UICanvas _enqueuePostSettingUpdateTransactionBlock:] + 153
        24  UIKitCore                           0x00000001156da2ec -[__UICanvasLifecycleMonitor_Compatability _scheduleFirstCommitForScene:transition:firstActivation:completion:] + 236
        25  UIKitCore                           0x00000001156dac48 -[__UICanvasLifecycleMonitor_Compatability activateEventsOnly:withContext:completion:] + 1091
        26  UIKitCore                           0x00000001156d8fba __82-[_UIApplicationCanvas _transitionLifecycleStateWithTransitionContext:completion:]_block_invoke + 782
        27  UIKitCore                           0x00000001156d8c71 -[_UIApplicationCanvas _transitionLifecycleStateWithTransitionContext:completion:] + 433
        28  UIKitCore                           0x00000001156dd9b6 __125-[_UICanvasLifecycleSettingsDiffAction performActionsForCanvas:withUpdatedScene:settingsDiff:fromSettings:transitionContext:]_block_invoke + 576
        29  UIKitCore                           0x00000001156de610 _performActionsWithDelayForTransitionContext + 100
        30  UIKitCore                           0x00000001156dd71d -[_UICanvasLifecycleSettingsDiffAction performActionsForCanvas:withUpdatedScene:settingsDiff:fromSettings:transitionContext:] + 223
        31  UIKitCore                           0x00000001156e26d0 -[_UICanvas scene:didUpdateWithDiff:transitionContext:completion:] + 392
        32  UIKitCore                           0x0000000115e939a8 -[UIApplication workspace:didCreateScene:withTransitionContext:completion:] + 514
        33  UIKitCore                           0x0000000115a4adfa -[UIApplicationSceneClientAgent scene:didInitializeWithEvent:completion:] + 361
        34  FrontBoardServices                  0x00000001133a4125 -[FBSSceneImpl _didCreateWithTransitionContext:completion:] + 448
        35  FrontBoardServices                  0x00000001133aded6 __56-[FBSWorkspace client:handleCreateScene:withCompletion:]_block_invoke_2 + 283
        36  FrontBoardServices                  0x00000001133ad700 __40-[FBSWorkspace _performDelegateCallOut:]_block_invoke + 53
        37  libdispatch.dylib                   0x000000010ecaddb5 _dispatch_client_callout + 8
        38  libdispatch.dylib                   0x000000010ecb12ba _dispatch_block_invoke_direct + 300
        39  FrontBoardServices                  0x00000001133df146 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 30
        40  FrontBoardServices                  0x00000001133dedfe -[FBSSerialQueue _performNext] + 451
        41  FrontBoardServices                  0x00000001133df393 -[FBSSerialQueue _performNextFromRunLoopSource] + 42
        42  CoreFoundation                      0x000000010d2e8be1 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
        43  CoreFoundation                      0x000000010d2e8463 __CFRunLoopDoSources0 + 243
        44  CoreFoundation                      0x000000010d2e2b1f __CFRunLoopRun + 1231
        45  CoreFoundation                      0x000000010d2e2302 CFRunLoopRunSpecific + 626
        46  GraphicsServices                    0x000000011034e2fe GSEventRunModal + 65
        47  UIKitCore                           0x0000000115e96ba2 UIApplicationMain + 140
        48  SpotMi-Dev                          0x000000010174287b main + 75
        49  libdyld.dylib                       0x000000010ed22541 start + 1
        )
        libc++abi.dylib: terminating with uncaught exception of type NSException

Ниже приведен код из didLaunchWithOptions:

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {

    #if DEVELOPMENT
        print("Development Mode Started")
    #else
        print("Production Mode Started")
    #endif
    FirebaseApp.configure()
    Messaging.messaging().delegate = self

    //other app functions

    return true
}

Я вызываю API Firebase в viewDidLoad контроллера инициализации. И это Сервис, через который он вызывается и это даже содержит крах.

class FBDataservice : NSObject {
    static var ds = FBDataservice() //<------ Creates Error here on every single crash related to this issue

let DB_URL: DatabaseReference = Database.database().reference()
let ST_URL: StorageReference = Storage.storage().reference()

private lazy var _REF_BASE = DB_URL

}

А потом я просто вызываю FBDataservice.ds._REF_BASE.child("something").observe( .Event, with (Datasnapshot)) в viewDidLoad или viewDidAppear. Я просто в основном извлекаю данные. А затем отправьте данные, такие как обновление приложения RunCounts, на didBecameActive в AppDelegate.

Любая помощь будет безмерно оценена. Ваше здоровье

Комментарии не предназначены для расширенного обсуждения или сеансов отладки; этот разговор был архив в чате.

Cody Gray 28.05.2019 08:01
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
2
1
1 668
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Проверьте FirebaseApp.app(), если это nil, вы можете вызвать FirebaseApp.configure() еще раз? Вам нужно отлаживать, если это дает сбой в методе appDidBecomeActive: или didEneterInForeground:.

Также проверьте, где вы используете FirebaseDatabase в первый раз после запуска приложения, кроме строки конфигурации? Я имею в виду в любом ViewController или где угодно, нам нужно проверить условие здесь.

Обновленный вопрос:

Что касается вашего обновленного вопроса FBDataservice(), где вы создаете свой экземпляр, потому что, когда вы создаете свой экземпляр, он будет создавать DB_URL и ST_URL экземпляры URL, которые связаны с Firebase, поэтому, вероятно, Firebase не настроен до этого. Вы можете переопределить его метод инициализации, чтобы проверить, настроен ли Firebase или нет.

Вы взяли две переменные, которые будут создаваться в конструкторе всякий раз, когда вы будете создавать экземпляр этого класса.

Попробуйте одну вещь... заменить

static var ds = FBDataservice() 

с участием

static var ds: FBDataservice { 
    if FirebaseApp.app() == nil { 
         FirebaseApp.configure() 
    } 
    return FBDataservice() 
}

Эй, я только что наткнулся на другую ошибку. Terminating app due to uncaught exception 'com.firebase.core', reason: 'Default app has already been configured.'Я полагаю, поскольку Config вызывается дважды, один раз в didFinishWithLaunch, а затем в экземпляре. Вы рекомендуете удалить тот, что в appdelegate?

Aakash Dave 28.05.2019 08:13

Я только что добавил ту же проверку FirebaseApp.app() в делегате. Так решил. Но вы предлагаете что-то еще?

Aakash Dave 28.05.2019 08:14

Попробуйте поставить такое же условие и в AppDelegate. if FirebaseApp.app() == nil { FirebaseApp.configure() }

TheTiger 28.05.2019 08:14

Другие вопросы по теме