回答每个命令的后续问题,并确保您看到Firebase configuration file lib/firebase/prod/firebase_options.dart generated successfully,以确保您的firebase_option已在正确的目录中创建。 您可以在firebase控制台中找到您的firebase-project-id:project overview > project setting > General > Project ID 顺便说一句,这里有一些关于flutterfire configure [arguments]的有用信息:
Usage: flutterfire configure [arguments]
-h, --help Print this usage information.
-p, --project=<aliasOrProjectId> The Firebase project to use for this command.
-e, --account=<email> The Google account to use for authorization.
-o, --out=<filePath> The output file path of the Dart file that will be generated with your Firebase configuration options.
(defaults to "lib/firebase_options.dart")
-i, --ios-bundle-id=<bundleIdentifier> The bundle identifier of your iOS app, e.g. "com.example.app". If no identifier is provided then an attempt will be made to automatically detect it from your "ios" folder (if it exists).
-m, --macos-bundle-id=<bundleIdentifier> The bundle identifier of your macOS app, e.g. "com.example.app". If no identifier is provided then an attempt will be made to automatically detect it from your "macos" folder (if it
exists).
-a, --android-app-id=<applicationId> The application id of your Android app, e.g. "com.example.app". If no identifier is provided, then an attempt will be made to automatically detect it from your "android" folder (if it
exists).
Run "flutterfire help" to see global options.
import UIKit
import Flutter
import FirebaseCore. //import this
import FirebaseDatabase // import this also
@UIApplicationMain
@objc class AppDelegate: FlutterAppDelegate {
override func application(
_ application: UIApplication,
didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
) -> Bool {
GeneratedPluginRegistrant.register(with: self)
// Configure with manual options. Note that projectID and apiKey,
though not
// required by the initializer, are mandatory.
//Now create the secondary app
let secondaryOptions = FirebaseOptions(googleAppID: "<your id from second google jsoninfo.plist>",
gcmSenderID: "<your id from second google jsoninfo.plist>")
secondaryOptions.apiKey = "<your id from second google jsoninfo.plist>"
secondaryOptions.projectID = "<your id from second google jsoninfo.plist>"
// The other options are not mandatory, but may be required
// for specific Firebase products.
secondaryOptions.bundleID = "<your id from second google jsoninfo.plist>"
//secondaryOptions.trackingID = "<your id from second google jsoninfo.plist>"
secondaryOptions.clientID = "<your id from second google jsoninfo.plist>"
secondaryOptions.databaseURL = "<your id from second google jsoninfo.plist>"
secondaryOptions.storageBucket = "<your id from second google jsoninfo.plist>"
secondaryOptions.androidClientID = "<your id from second google jsoninfo.plist>"
//secondaryOptions.deepLinkURLScheme = "<your id from second google jsoninfo.plist>"
secondaryOptions.appGroupID = nil
// Configure an alternative SecondaryApp.
FirebaseApp.configure(name: "SecondaryApp", options: secondaryOptions)
// Retrieve a previous created named app.
guard let secondary = FirebaseApp.app(name: "SecondaryApp")
else { assert(false, "Could not retrieve SecondaryApp") }
// Retrieve a Real Time Database client configured against a specific app.
let secondaryDb = Database.database(app: secondary)
return super.application(application, didFinishLaunchingWithOptions: launchOptions)
}
}
4条答案
按热度按时间bnl4lu3b1#
正如您提到的创建应用程序的正常方式,您可以使用Firebase CLI以相同的方式创建Firebase应用程序,它将为您工作。您需要做的就是创建第二个应用程序,但您需要为第二个应用程序指定名称。如果您在默认情况下创建Firebase示例时不使用名称,则使用首先配置的Firebase项目。或者您可以在main.dart中手动指定FirebaseOptions,如下所示。
下面的代码将帮助您了解如何在一个应用中使用两个单独的Firebase项目,或根据需要使用多个项目。
在上面的代码中,您将手动分配此基于CLI的代码正在执行的ID
这个DefaultFirebaseOptions的作用是在执行过程中根据平台创建Firebase应用。如果您使用CLI初始化Firebase,则在lib/firebase_options.dart文件中处理。如果您手动添加Android文件夹中的google-services.json文件和iOS中的GoogleServices-info.plist文件,则也会包含类似的ID。
dfddblmv2#
要将Flutter应用连接到Firebase项目,您可以用途:
默认情况下,将添加
lib/firebase_option.dart
文件例如,如果你想集成两个独立的firebase项目,一个用于
dev
,另一个用于prod
,你可以创建两个目录:然后分别运行这些:
回答每个命令的后续问题,并确保您看到
Firebase configuration file lib/firebase/prod/firebase_options.dart generated successfully
,以确保您的firebase_option已在正确的目录中创建。您可以在firebase控制台中找到您的firebase-project-id:
project overview > project setting > General > Project ID
顺便说一句,这里有一些关于flutterfire configure [arguments]的有用信息:
This article详细解释了flutter和firebase的多环境。
e7arh2l63#
你可以尝试通过添加flutter口味
https://codewithandrea.com/articles/flutter-flavors-for-firebase-apps/
yws3nbqq4#
在iOS中初始化两个Firebase应用:
步骤1:初始化Flutter主文件中的默认应用程序
第2步:在appdelegate文件中手动初始化第二个firebase应用,app目录中的第二个应用不需要
googlejsoninfo.plist
。注意:所有选项都不是必须填写的,仅在
googlejsoninfo.plist
文件中可用参考:https://firebase.google.com/docs/projects/multiprojects