توضِّح هذه الصفحة كيفية استخدام أكثر من مشروع واحد على Firebase في تطبيقك.
لا تحتاج العديد من التطبيقات إلا إلى مشروع واحد على Firebase والإعداد التلقائي الموضّح في أدلة البدء. في ما يلي أمثلة على الحالات التي قد يكون فيها استخدام مشاريع متعددة على Firebase مفيدًا:
- إعداد بيئة التطوير لاستخدام مشاريع مختلفة على Firebase استنادًا إلى نوع التصميم أو الهدف
- الوصول إلى المحتوى من مشاريع متعددة على Firebase في تطبيقك
دعم بيئات مختلفة
من حالات الاستخدام الشائعة دعم مشاريع منفصلة على Firebase لبيئتَي التطوير والإنتاج.
يتم ضبط حِزم SDK للويب والمشرف من خلال تمرير القيم مباشرةً إلى دوال الإعداد. بالنسبة إلى حِزم SDK هذه، يمكنك استخدام عملية تحقّق في وقت التشغيل لاختيار متغيّرات إعداد التطوير أو الإنتاج.
تحمِّل منصّتا Android وApple (والأغلفة البرمجية Unity وC++) عادةً الإعدادات من ملف إعداد: GoogleService-Info.plist على منصّة Apple وgoogle-services.json على Android. تتم قراءة هذه الملفات في عنصر خيارات (FIROption أو FirebaseOptions) يُشير إليه عنصر تطبيق Firebase (FIRApp أو FirebaseApp).
بالنسبة إلى هاتَين المنصّتَين، يتم عادةً تنفيذ التبديل بين البيئات كقرار في وقت التصميم، من خلال استخدام ملفات إعداد مختلفة لكل بيئة.
دعم بيئات متعددة في تطبيقك على Apple
سيحمِّل FirebaseApp.configure() تلقائيًا ملف GoogleService-Info.plist المجمّع مع التطبيق. إذا تم ضبط بيئتَي التطوير والإنتاج كهدفَين منفصلَين في Xcode، يمكنك إجراء ما يلي:
- تنزيل كلا ملفَي
GoogleService-Info.plist - تخزين الملفَين في دليلَين مختلفَين
- إضافة كلا الملفَين إلى مشروعك على Xcode
- ربط الملفات المختلفة بالأهداف المختلفة باستخدام لوحة Target Membership:

إذا كانت التصميمات جزءًا من هدف واحد، فإنّ الخيار الأفضل هو منح كلا ملفَي الإعداد اسمَين فريدَين (مثل GoogleService-Info-Free.plist وGoogleService-Info-Paid.plist). بعد ذلك، اختَر في وقت التشغيل ملف plist الذي تريد تحميله.
يظهر ذلك في المثال التالي:
// Load a named file. guard let filePath = Bundle.main.path(forResource: "MyGoogleService", ofType: "plist"), let fileOptions = FirebaseOptions(contentsOfFile: filePath) else { fatalError("Couldn't load config file.") } FirebaseApp.configure(options: fileOptions)
دعم بيئات متعددة في تطبيق Android
في Android، تتم معالجة ملف google-services.json وتحويله إلى موارد سلسلة Android من خلال المكوّن الإضافي لـ Gradle من "خدمات Google". يمكنك الاطّلاع على
الموارد التي يتم إنشاؤها في مستندات المكوّن الإضافي لـ "خدمات Google" في مقالة
معالجة ملف JSON.
يمكنك استخدام ملفات google-services.json متعددة لـ
خيارات تصميم
مختلفة من خلال وضع ملفات google-services.json في أدلة مخصّصة تحمل اسم كل
خيار ضمن جذر وحدة التطبيق. على سبيل المثال، إذا كان لديك خيارا تصميم "development" و"release"، يمكن تنظيم الإعدادات على النحو التالي:
app/
google-services.json
src/development/google-services.json
src/release/google-services.json
...
لمزيد من المعلومات، يُرجى الاطّلاع على مستندات المكوّن الإضافي لـ "خدمات Google" في مقالة إضافة ملف JSON.
بعد ذلك، يتم تحميل هذه الموارد من خلال FirebaseInitProvider، الذي يتم تشغيله قبل الرمز البرمجي لتطبيقك ويضبط واجهات Firebase API باستخدام هذه القيم.
بما أنّ هذا الموفّر يقرأ فقط الموارد التي تحمل أسماء معروفة، فإنّ هناك خيارًا آخر يتمثل في إضافة موارد السلسلة مباشرةً إلى تطبيقك بدلاً من استخدام المكوّن الإضافي لـ Gradle من "خدمات Google". يمكنك إجراء ذلك من خلال ما يلي:
- إزالة المكوّن الإضافي
google-servicesمن ملفbuild.gradleالجذر - حذف ملف
google-services.jsonمن مشروعك - إضافة موارد السلسلة مباشرةً
- حذف
apply plugin: 'com.google.gms.google-services'من ملفbuild.gradleالخاص بتطبيقك
استخدام مشاريع متعددة في تطبيقك
في بعض الأحيان، تحتاج إلى الوصول إلى مشاريع مختلفة باستخدام واجهات برمجة التطبيقات نفسها، على سبيل المثال، الوصول إلى مثيلات متعددة من قاعدة البيانات. في معظم الحالات، يكون هناك عنصر تطبيق مركزي على Firebase يدير الإعدادات لجميع واجهات Firebase API. يتم إعداد هذا العنصر كجزء من عملية الإعداد العادية. ومع ذلك، عندما تريد الوصول إلى مشاريع متعددة من تطبيق واحد، ستحتاج إلى عنصر تطبيق منفصل على Firebase للإشارة إلى كل مشروع على حدة. ويقع على عاتقك إعداد هذه المثيلات الأخرى.
في كلتا الحالتَين، عليك أولاً إنشاء عنصر خيارات Firebase لتخزين بيانات إعداد تطبيق Firebase. يمكنك الاطّلاع على المستندات الكاملة للخيارات في المستندات المرجعية لواجهة برمجة التطبيقات للفئتَين التاليتَين:
- Swift:
FirebaseOptions(googleAppID:gcmSenderID:) - Android:
FirebaseOptions.Builder - الويب:
initializeApp() - C++:
firebase::App::Create - Unity:
FirebaseApp.Create - Node.js:
initializeApp - Java:
FirebaseOptions.Builder
يظهر استخدام هاتَين الفئتَين لدعم مشاريع متعددة في تطبيق في الأمثلة التالية:
Swift
// Configure with manual options. Note that projectID and apiKey, though not // required by the initializer, are mandatory. let secondaryOptions = FirebaseOptions(googleAppID: "1:27992087142:ios:2a4732a34787067a", gcmSenderID: "27992087142") secondaryOptions.apiKey = "AIzaSyBicqfAZPvMgC7NZkjayUEsrepxuXzZDsk" secondaryOptions.projectID = "projectid-12345" // The other options are not mandatory, but may be required // for specific Firebase products. secondaryOptions.bundleID = "com.google.firebase.devrel.FiroptionConfiguration" secondaryOptions.clientID = "27992087142-ola6qe637ulk8780vl8mo5vogegkm23n.apps.googleusercontent.com" secondaryOptions.databaseURL = "https://myproject.firebaseio.com" secondaryOptions.storageBucket = "myproject.appspot.com" secondaryOptions.deepLinkURLScheme = "myapp://" secondaryOptions.storageBucket = "projectid-12345.appspot.com" secondaryOptions.appGroupID = nil
Kotlin
// Manually configure Firebase Options. The following fields are REQUIRED: // - Project ID // - App ID // - API Key val options = FirebaseOptions.Builder() .setProjectId("my-firebase-project") .setApplicationId("1:27992087142:android:ce3b6448250083d1") .setApiKey("AIzaSyADUe90ULnQDuGShD9W23RDP0xmeDc6Mvw") // .setDatabaseUrl(...) // .setStorageBucket(...) .build()
Java
// Manually configure Firebase Options. The following fields are REQUIRED: // - Project ID // - App ID // - API Key FirebaseOptions options = new FirebaseOptions.Builder() .setProjectId("my-firebase-project") .setApplicationId("1:27992087142:android:ce3b6448250083d1") .setApiKey("AIzaSyADUe90ULnQDuGShD9W23RDP0xmeDc6Mvw") // setDatabaseURL(...) // setStorageBucket(...) .build();
على الويب
// The following fields are REQUIRED: // - Project ID // - App ID // - API Key const secondaryAppConfig = { projectId: "<PROJECT_ID>", appId: "<APP_ID>", apiKey: "<API_KEY>", // databaseURL: "...", // storageBucket: "...", };
C++
firebase::AppOptions secondary_app_options;
// API key, app ID, and project ID are always required.
secondary_app_options.set_api_key("<API_KEY>");
secondary_app_options.set_app_id("<GOOGLE_APP_ID>");
secondary_app_options.set_project_id("<PROJECT_ID>");
// The following options are specific to individual Firebase products
// and may not always be required.
secondary_app_options.set_database_url("<DATABASE_URL>");
secondary_app_options.set_messaging_sender_id("<SENDER_ID>");
secondary_app_options.set_storage_bucket("<STORAGE_BUCKET>");
Unity
Firebase.AppOptions secondaryAppOptions = new Firebase.AppOptions {
ApiKey = "<API_KEY>",
AppId = "<GOOGLE_APP_ID>",
ProjectId = "<PROJECT_ID>"
};
Node.js
const secondaryServiceAccount = require('./path/to/serviceAccountKey.json'); // All required options are specified by the service account, // add service-specific configuration like databaseURL as needed. const secondaryAppConfig = { credential: cert(secondaryServiceAccount), // databaseURL: 'https://<DATABASE_NAME>.firebaseio.com' };
Java
FileInputStream serviceAccount = new FileInputStream("path/to/serviceAccountKey.json");
FirebaseOptions secondaryAppConfig = new FirebaseOptions.Builder()
.setCredential(FirebaseCredentials.fromCertificate(serviceAccount))
.setDatabaseUrl("https://<DATABASE_NAME>.firebaseio.com/")
.build();
بعد إعداد عنصر الخيارات هذا، يمكنك استخدامه لإعداد مثيل إضافي لتطبيق Firebase. يُرجى العِلم أنّنا نستخدم السلسلة secondary في جميع الأمثلة الموضّحة أدناه. يُستخدم هذا الاسم لاسترداد مثيل التطبيق وتمييزه عن المثيلات الأخرى، بما في ذلك المثيل التلقائي (الذي يحمل الاسم [DEFAULT]). عليك اختيار سلسلة مناسبة للاستخدام المقصود لمشروع Firebase الآخر.
توضِّح المقتطفات التالية كيفية الاتصال بقاعدة بيانات بديلة Realtime Database (تتّبع واجهات برمجة التطبيقات لميزات Firebase الأخرى النمط نفسه).
Swift
// Configure an alternative FIRApp. FirebaseApp.configure(name: "secondary", options: secondaryOptions) // Retrieve a previous created named app. guard let secondary = FirebaseApp.app(name: "secondary") else { fatalError("Could not retrieve secondary app") } // Retrieve a Real Time Database client configured against a specific app. let secondaryDb = Database.database(app: secondary)
Kotlin
// Initialize secondary FirebaseApp. Firebase.initialize(context = this, options, "secondary") // Retrieve secondary FirebaseApp. val secondary = Firebase.app("secondary") // Get the database for the other app. val secondaryDatabase = Firebase.database(secondary)
Java
// Initialize with secondary app FirebaseApp.initializeApp(this /* Context */, options, "secondary"); // Retrieve secondary FirebaseApp FirebaseApp secondary = FirebaseApp.getInstance("secondary");
على الويب
// Initialize another app with a different config const secondaryApp = firebase.initializeApp(secondaryAppConfig, "secondary"); // Access services, such as the Realtime Database // secondaryApp.database();
C++
firebase::App* secondary_app = firebase::App::Create(secondary_app_options, "Secondary");
firebase::database::Database* secondary_database = firebase::database::Database::GetInstance(secondary_app);
Unity
var secondaryApp = Firebase.FirebaseApp.Create(secondaryAppOptions, "Secondary"));
var secondaryDatabase = Firebase.Database.FirebaseDatabase.getInstance(secondaryApp);
Node.js
// Initialize another app with a different config const secondary = initializeApp(secondaryAppConfig, 'secondary'); // Access services, such as the Realtime Database // const secondaryDatabase = secondary.database();
Java
// Initialize another app with a different config
FirebaseApp secondaryApp = FirebaseApp.initializeApp(secondaryAppConfig, "secondary");
// Retrieve the database.
FirebaseDatabase secondaryDatabase = FirebaseDatabase.getInstance(secondaryApp);
ضمان إعداد تقارير موثوقة في Analytics
Google Analytics تجمع الأحداث في مرحلة مبكرة جدًا من عملية بدء تشغيل التطبيق، وفي
بعض الحالات قبل إعداد مثيل تطبيق Firebase الأساسي. في هذه الحالات، يشير Firebase إلى مورد Android أو GoogleService-Info.plist على منصّات Apple للبحث عن رقم تعريف تطبيق Google الصحيح لتخزين الأحداث. لهذا السبب، ننصحك باستخدام طُرق الإعداد التلقائية حيثما أمكن ذلك.
إذا كان الإعداد في وقت التشغيل مطلوبًا، يُرجى ملاحظة التحذيرات التالية:
- إذا كنت تستخدم AdMob وتطلب الإعلانات عند بدء التشغيل كما ننصحك بذلك، قد تفقد بعض بيانات "إحصاءات Google" ذات الصلة بالإعلانات على الأجهزة الجوّالة عند عدم استخدام نهج الإعداد المستند إلى الموارد.
- يجب عدم تقديم سوى رقم تعريف تطبيق Google واحد في كل خيار من خيارات التطبيق الموزَّعة. على سبيل المثال، إذا أرسلت الإصدار 1 من تطبيقك مع
GOOGLE_APP_IDمعيّن في الإعدادات، ثم حمّلت الإصدار 2 برقم تعريف مختلف، قد يؤدي ذلك إلى فقدان بيانات "إحصاءات Google". - على منصّات Apple، لا تُضِف ملف GoogleService-Info.plist إلى مشروعك إذا كنت تقدّم إعدادات مختلفة في وقت التشغيل، لأنّ ذلك قد يؤدي إلى تغيير واضح في
GOOGLE_APP_IDوفقدان بيانات "إحصاءات Google".