使用 Firebase 身份验证时应用程序崩溃,原因:“已配置默认应用程序。”

Posted

技术标签:

【中文标题】使用 Firebase 身份验证时应用程序崩溃,原因:“已配置默认应用程序。”【英文标题】:App crashing when using Firebase Auth, reason: 'Default app has already been configured.' 【发布时间】:2016-10-21 00:21:54 【问题描述】:

我正在构建我的第一个 ios 应用程序,我正在使用 Firebase 来处理身份验证、数据库等。我添加了一个注册屏幕并使用以下代码创建了一个新用户:

FIRAuth.auth()?.createUserWithEmail(emailAddress.text!, password: password.text!, completion:  (user, error) in

        )

当用户点击注册按钮时,会有一个转场将他们带回原来的登录视图控制器。但是,当我运行该应用程序时,它会挂在启动屏幕上。这是调试器的输出:

2016-06-19 14:35:05.402 unitaskr[4386:82981] Configuring the default app.
2016-06-19 14:35:05.413 unitaskr[4386:] <FIRAnalytics/INFO> Firebase Analytics     v.3200000 started
2016-06-19 14:35:05.414 unitaskr[4386:] <FIRAnalytics/INFO> To enable debug logging set the following application argument: -FIRAnalyticsDebugEnabled (see ...)
2016-06-19 14:35:05.419: <FIRInstanceID/WARNING> FIRInstanceID AppDelegate proxy enabled, will swizzle app delegate remote notification handlers. To disable add "FirebaseAppDelegateProxyEnabled" to your Info.plist and set it to NO
2016-06-19 14:35:05.418 unitaskr[4386:] <FIRAnalytics/INFO> Successfully created Firebase Analytics App Delegate Proxy automatically. To disable the proxy, set the flag FirebaseAppDelegateProxyEnabled to NO in the Info.plist
2016-06-19 14:35:05.430 unitaskr[4386:82981] *** Terminating app due to uncaught exception 'com.firebase.core', reason: 'Default app has already been configured.'
*** First throw call stack:
(
0   CoreFoundation                      0x00000001100a8d85   __exceptionPreprocess + 165
1   libobjc.A.dylib                     0x00000001108e7deb objc_exception_throw + 48
2   CoreFoundation                      0x00000001100a8cbd +[NSException raise:format:] + 205
3   unitaskr                            0x000000010b58844d +[FIRApp    configureDefaultAppWithOptions:sendingNotifications:] + 102
4   unitaskr                            0x000000010b588238 +[FIRApp configure] + 302
5   unitaskr                            0x000000010b541f1a _TFC8unitaskr11AppDelegate11applicationfTCSo13UIApplication29didFinishLaunchingWithOptionsGSqGVs10DictionaryCSo8NSObjectPs9AnyObject____Sb + 266
6   unitaskr                            0x000000010b542204 _TToFC8unitaskr11AppDelegate11applicationfTCSo13UIApplication29didFinishLaunchingWithOptionsGSqGVs10DictionaryCSo8NSObjectPs9AnyObject____Sb + 180
7   UIKit                               0x000000010e5bf9ac -[UIApplication _handleDelegateCallbacksWithOptions:isSuspended:restoreState:] + 272
8   UIKit                               0x000000010e5c0c0d -[UIApplication _callInitializationDelegatesForMainScene:transitionContext:] + 3415
9   UIKit                               0x000000010e5c7568 -[UIApplication _runWithMainScene:transitionContext:completion:] + 1769
10  UIKit                               0x000000010e5c4714 -[UIApplication workspaceDidEndTransaction:] + 188
11  FrontBoardServices                  0x00000001127b78c8 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 24
12  FrontBoardServices                  0x00000001127b7741 -[FBSSerialQueue _performNext] + 178
13  FrontBoardServices                  0x00000001127b7aca -[FBSSerialQueue _performNextFromRunLoopSource] + 45
14  CoreFoundation                      0x000000010ffce301 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
15  CoreFoundation                      0x000000010ffc422c __CFRunLoopDoSources0 + 556
16  CoreFoundation                      0x000000010ffc36e3 __CFRunLoopRun + 867
17  CoreFoundation                      0x000000010ffc30f8 CFRunLoopRunSpecific + 488
18  UIKit                               0x000000010e5c3f21 -[UIApplication _run] + 402
19  UIKit                               0x000000010e5c8f09 UIApplicationMain + 171
20  unitaskr                            0x000000010b542a42 main + 114
21  libdyld.dylib                       0x00000001113b692d start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb) 

我可以根据需要提供更多信息,任何帮助/建议将不胜感激,因为我刚刚开始并希望尽可能多地学习。祝你有美好的一天!

【问题讨论】:

【参考方案1】:

我写了两次FIRApp.configure(),似乎解决了错误。

【讨论】:

我不小心做了同样的事情,它抛出了同样的错误。你应该没有问题了! 谢谢兄弟,我也犯了同样的错误 那可能是因为没有 .plist 文件,根本没有注册。【参考方案2】:

AppDelegate init 方法中调用一次即可进行配置。

override init() 
   // Firebase Init
   FIRApp.configure()

【讨论】:

我在没有 AppDelegate 类的扩展键盘类中调用此方法。那我该怎么办? 尝试在您的视图控制器 viewDidLoad 中调用它。覆盖 func viewDidLoad() 但这就是问题所在,因为如果我将我的扩展键盘更改为本机并将本机更改为扩展,那么它会崩溃并抛出相同的错误。 你可以扩展视图控制器并调用它们两次吗?并重新检查 override func viewDidLoad() super.viewDidLoad() FIRApp.configure() //这是我在键盘扩展 UIInputViewController 类中编写的。但是,当我将键盘切换到本机 ios 键盘并再次切换到我的键盘时,会调用此方法并发生崩溃,并出现此 错误- [原因:'默认应用程序已配置。']【参考方案3】:

以防万一其他人偶然发现这个问题。 当使用firebase sdk 和googleSignIn sdk 时。您只需配置一次。要么做 [[GGLContext sharedInstance] configureWithError: &configureError]; 要么 [FIRApp configure]

【讨论】:

【参考方案4】:

我遇到了 Messages Extension 问题:

如果您在 App Extension 中,则您没有委托,并且您必须将 FIRApp.configure() 放在主 ViewController 的 init 中(或在 viewDidLoad 中作为建议)。

问题是:在消息扩展中,如果用户在打开扩展的线程中按下多条消息,init(或 viewdidLoad)将被多次调用,因此由于 FIRApp.configure() 多次调用而崩溃......

我找到的解决方案是在主视图控制器中创建一个静态布尔值:

    static var isAlreadyLaunchedOnce = false // Used to avoid 2 FIRApp configure

我在 init 或 viewDidLoad 中调用 FIRApp.configure() 之前对其进行测试:

// Configure Firebase
    // ------------------
    // We check if FIRApp has already been configured with a static var, else it will crash...
    if !MessagesViewController.isAlreadyLaunchedOnce 
        FIRApp.configure()

        MessagesViewController.isAlreadyLaunchedOnce = true
    

这样,就不会再崩溃了。


哦,我在这里找到了一种更优雅的解决问题的方法: iOS Extension - Fatal Exception: com.firebase.core Default app has already been configured

    // Configure Firebase
    // ------------------
    if FIRApp.defaultApp() == nil 
        FIRApp.configure()            
    

这种方式不再是静态的;)

【讨论】:

这很好。在扩展上下文中使用它。 是的,唯一的缺点是我们得到了一个关于 firebase 尚未配置的烦人日志。 如果 FIRApp.defaultApp() == nil FIRApp.configure() 为我工作,谢谢! 如果 FirebaseApp.app() == nil FirebaseApp.configure() 【参考方案5】:

类名:AppDelegate+FCMPlugin.m

[FIRApp.configure()];

把这个放在这个方法的最上面

- (BOOL)application:(UIApplication *)application customDidFinishLaunchingWithOptions:(NSDictionary *)launchOptions 
 if(![FIRApp defaultApp])
    [FIRApp configure];

【讨论】:

这对我有用。但问题是为什么?我是 Flutter for iOS 的新手,昨晚这一直困扰着我。【参考方案6】:

对于 Swift 4

遇到同样的崩溃问题。尝试使用 .plist 文件从 Firebase 引用时。

(这解决了我的问题。)

尝试在 viewDidLoad 方法之外或之内写这个:

1. var ref: DatabaseReference!

然后在 viewDidLoad 方法中引用它:

2. Database.database().reference()

现在是:

FirebaseApp.configure()

相反。

【讨论】:

【参考方案7】:

这是有关此问题的其他解决方案。 1/检查“AppDelegate.swift”,我们将看到如下

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool 
    // Override point for customization after application launch.
    FirebaseApp.configure()
    return true

2/ 从上面的代码中删除“FirebaseApp.configure()”到

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool 
    // Override point for customization after application launch.

    return true

3/ 将以下代码添加到“AppDelegate.swift”中

override init() 
    FirebaseApp.configure()

4/ 转到“ViewController.swift”并添加代码

    if FirebaseApp.app() == nil 
        FirebaseApp.configure()
    

5/ 再次构建并运行它会起作用。谢谢!

【讨论】:

【参考方案8】:

对于 Swift 4,

if FirebaseApp.app() == nil 
/// code snippet

【讨论】:

【参考方案9】:

如果您正在使用 Scene 委托,并且您有 不同的 iOS 版本,例如 9、10 到 13,则必须以这种方式调用 AppDelegate.swift

 if #available(iOS 13.0, *) 
 
  else 
     FirebaseApp.configure()
 

SceneDelegate.swift 中这样:

 if #available(iOS 13.0, *) 
   FirebaseApp.configure()
 

这些设置将排除错误,例如: *

*** 由于未捕获的异常“com.firebase.core”而终止应用程序,原因:“已配置默认应用程序。”

【讨论】:

【参考方案10】:

这是我的 AppDelegate.swift 代码

import UIKit
import Flutter
import Firebase

@UIApplicationMain
@objc class AppDelegate: FlutterAppDelegate 
  override func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool 
    GeneratedPluginRegistrant.register(with: self)
  FirebaseApp.configure()
    return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  

您可以将此FirebaseApp.configure() 删除或添加

 if #available(iOS 13.0, *) 
 
  else 
     FirebaseApp.configure()
 

两者都为我工作

【讨论】:

【参考方案11】:

这是因为您已经在 AppDelegate 中初始化了 FirebaseApp.configure()请确保它只配置一次并且错误应该消失。

【讨论】:

以上是关于使用 Firebase 身份验证时应用程序崩溃,原因:“已配置默认应用程序。”的主要内容,如果未能解决你的问题,请参考以下文章

使用带有 Firebase 身份验证的 ProGuard 构建 Flutter 崩溃

Flutter Firebase 身份验证与 Google 应用程序崩溃

使用 Firebase Auth 进行身份验证时,短信验证码请求失败

Flutter 应用程序在 iOS 平台上的 Firebase 手机身份验证上崩溃

在Firebase身份验证后启动MainActivity

iOS 上的 Firebase 应用检查在构建时崩溃