Добавьте Firebase в свой проект C++

Расширьте возможности своих игр на C++ с помощью наших SDK Firebase C++, которые предоставляют интерфейс C++ поверх SDK Firebase.

Access Firebase entirely from your C++ code, without having to write any platform-native code. The Firebase SDK also translates many language-specific idioms used by Firebase into an interface more familiar to C++ developers.

Более подробную информацию о том, как расширить возможности ваших игр с помощью Firebase, вы найдете на нашей странице, посвященной играм Firebase .

Уже добавили Firebase в свой проект на C++? Убедитесь, что используете последнюю версию Firebase C++ SDK .


Предварительные требования

  • Установите предпочитаемый вами редактор или IDE, например Android Studio, IntelliJ или VS Code.

  • Obtain the Android SDK .

  • Убедитесь, что ваш проект соответствует следующим требованиям:

    • Для работы требуется API уровня 23 (Marshmallow) или выше.

    • Uses Gradle and is configured with CMake

  • Для запуска приложения подключите физическое устройство или используйте эмулятор.

    • Эмуляторы должны использовать образ эмулятора с Google Play.

    • Для некоторых библиотек C++ на клиентском устройстве требуются сервисы Google Play; ознакомьтесь со списком на этой странице.

  • Войдите в Firebase, используя свою учетную запись Google.

Step 2 : Create a Firebase project

Прежде чем добавить Firebase в свой проект C++, необходимо создать проект Firebase для подключения к вашему проекту C++. Подробнее о проектах Firebase можно узнать в разделе «Понимание проектов Firebase».

Шаг 3 : Зарегистрируйте свое приложение в Firebase.

Чтобы использовать Firebase в своем Android-приложении, вам необходимо зарегистрировать его в своем проекте Firebase. Регистрация приложения часто называется «добавлением» приложения в проект.

  1. Перейдите в консоль Firebase .

  2. В центре страницы обзора проекта нажмите на значок Android ( ) или «Добавить приложение» , чтобы запустить процесс настройки.

  3. Введите имя пакета вашего приложения в поле «Имя пакета Android» .

  4. (Необязательно) Введите псевдоним приложения — внутренний, удобный идентификатор, видимый только вам в консоли Firebase .

  5. Нажмите «Зарегистрировать приложение» .

Шаг 4 : Добавьте файл конфигурации Firebase.

  1. Нажмите «Скачать google-services.json» , чтобы получить файл конфигурации Firebase для Android.

  2. Open your C++ project in an IDE, then add your config file to your project:

  3. (Только для сборки Gradle) Чтобы включить сервисы Firebase в вашем проекте C++, добавьте плагин google-services в главный файл build.gradle .

    1. Добавьте правила для включения плагина Google Services Gradle. Также убедитесь, что у вас есть репозиторий Maven от Google.

        buildscript {
      
          repositories {
            // Check that you have the following line (if not, add it):
            google()  // Google's Maven repository
          }
      
          dependencies {
            // ...
      
            // Add the following lines:
            classpath 'com.google.gms:google-services:4.4.4'  // Google Services plugin
            implementation 'com.google.android.gms:18.10.0'
          }
        }
      
        allprojects {
          // ...
      
          repositories {
            // Check that you have the following line (if not, add it):
            google()  // Google's Maven repository
            // ...
          }
        }
      
    2. Apply the Google Services Gradle plugin:

        apply plugin: 'com.android.application'
        // Add the following line:
        apply plugin: 'com.google.gms.google-services'  // Google Services plugin
      
        android {
          // ...
        }
      
  4. Настройка задач в консоли Firebase завершена. Перейдите к разделу «Добавление SDK Firebase C++» ниже.

Step 5 : Add Firebase C++ SDKs

Описанные в этом разделе шаги представляют собой пример того, как добавить поддерживаемые продукты Firebase в ваш проект Firebase C++.

  1. Download the Firebase C++ SDK , then unzip the SDK somewhere convenient.

    SDK Firebase C++ не является платформенно-зависимым, но содержит платформенно-специфичные библиотеки.

  2. В файле gradle.properties вашего проекта укажите расположение распакованного SDK:

    systemProp.firebase_cpp_sdk.dir=full-path-to-SDK
  3. В файл settings.gradle вашего проекта добавьте следующее содержимое:

    def firebase_cpp_sdk_dir = System.getProperty('firebase_cpp_sdk.dir')
    
    gradle.ext.firebase_cpp_sdk_dir = "$firebase_cpp_sdk_dir"
    includeBuild "$firebase_cpp_sdk_dir"
  4. В файл Gradle вашего модуля (уровня приложения) (обычно app/build.gradle ) добавьте следующее содержимое.
    Добавьте зависимости библиотек для продуктов Firebase, которые вы хотите использовать в своем приложении.

    Analytics включена

    android.defaultConfig.externalNativeBuild.cmake {
    arguments "-DFIREBASE_CPP_SDK_DIR=$gradle.firebase_cpp_sdk_dir"
    }
    
    # Add the dependencies for the Firebase products you want to use in your app
    # For example, to use Analytics, Firebase Authentication, and Firebase Realtime Database
    apply from: "$gradle.firebase_cpp_sdk_dir/Android/firebase_dependencies.gradle"
    firebaseCpp.dependencies {
      analytics
      auth
      database
    }

    Analytics отключена

    android.defaultConfig.externalNativeBuild.cmake {
    arguments "-DFIREBASE_CPP_SDK_DIR=$gradle.firebase_cpp_sdk_dir"
    }
    
    # Add the dependencies for the Firebase products you want to use in your app
    # For example, to use Firebase Authentication and Firebase Realtime Database
    apply from: "$gradle.firebase_cpp_sdk_dir/Android/firebase_dependencies.gradle"
    firebaseCpp.dependencies {
      auth
      database
    }
  5. В файл CMakeLists.txt вашего проекта добавьте следующее содержимое.
    Включите библиотеки для продуктов Firebase, которые вы хотите использовать в своем приложении.

    Analytics включена

    # Add Firebase libraries to the target using the function from the SDK.
    add_subdirectory(${FIREBASE_CPP_SDK_DIR} bin/ EXCLUDE_FROM_ALL)
    
    # The Firebase C++ library `firebase_app` is required,
    # and it must always be listed last.
    
    # Add the Firebase SDKs for the products you want to use in your app
    # For example, to use Analytics, Firebase Authentication, and Firebase Realtime Database
    set(firebase_libs
      firebase_analytics
      firebase_auth
      firebase_database
      firebase_app
    )
    target_link_libraries(${target_name} "${firebase_libs}")

    Analytics отключена

    # Add Firebase libraries to the target using the function from the SDK.
    add_subdirectory(${FIREBASE_CPP_SDK_DIR} bin/ EXCLUDE_FROM_ALL)
    
    # The Firebase C++ library `firebase_app` is required,
    # and it must always be listed last.
    
    # Add the Firebase SDKs for the products you want to use in your app
    # For example, to use Firebase Authentication and Firebase Realtime Database
    set(firebase_libs
      firebase_auth
      firebase_database
      firebase_app
    )
    target_link_libraries(${target_name} "${firebase_libs}")
  6. Синхронизируйте приложение, чтобы убедиться, что все зависимости имеют необходимые версии.

  7. Если вы добавили Analytics , запустите приложение, чтобы отправить в Firebase подтверждение успешной интеграции. В противном случае, этап подтверждения можно пропустить.

    Your device logs will display the Firebase verification that initialization is complete. If you ran your app on an emulator that has network access, the Firebase console notifies you that your app connection is complete.

Всё готово! Ваше приложение на C++ зарегистрировано и настроено для использования сервисов Firebase.

Доступные библиотеки

Узнайте больше о библиотеках Firebase для C++ в справочной документации и в нашем SDK с открытым исходным кодом на GitHub .

Доступные библиотеки для Android (с использованием CMake)

Обратите внимание, что библиотеки C++ для платформ Apple перечислены в версии этой страницы настроек для платформ Apple (iOS+) .

Продукт Firebase Библиотечные ссылки
( firebaseCpp.dependencies
(для файла build.gradle )
Библиотечные ссылки
( firebase_libs
(для файла CMakeLists.txt )
AdMob admob firebase_admob
(обязательно) firebase_analytics
(обязательно) firebase_app
Analytics analytics firebase_analytics
(обязательно) firebase_app
App Check appCheck firebase_app_check
(обязательно) firebase_app
Authentication auth firebase_auth
(обязательно) firebase_app
Cloud Firestore firestore firebase_firestore
(обязательно) firebase_auth
(обязательно) firebase_app
Cloud Functions functions firebase_functions
(обязательно) firebase_app
Cloud Messaging messaging firebase_messaging
(рекомендуется) firebase_analytics
(обязательно) firebase_app
Cloud Storage storage firebase_storage
(обязательно) firebase_app
Dynamic Links dynamicLinks firebase_dynamic_links
(рекомендуется) firebase_analytics
(обязательно) firebase_app
Realtime Database database firebase_database
(обязательно) firebase_app
Remote Config remoteConfig firebase_remote_config
(рекомендуется) firebase_analytics
(обязательно) firebase_app

Дополнительная информация по настройке мобильного устройства.

Получайте отчеты о сбоях NDK.

Firebase Crashlytics поддерживает отправку отчетов о сбоях для приложений, использующих нативные библиотеки Android. Для получения дополнительной информации см. раздел «Получение отчетов о сбоях Android NDK» .

Системы, созданные по индивидуальному заказу

Firebase provides the script generate_xml_from_google_services_json.py to convert google-services.json to .xml resources that you can include in your project. This script applies the same transformation that the Google Play services Gradle plugin performs when building Android applications.

Если вы не используете Gradle для сборки (например, ndk-build, makefiles, Visual Studio и т. д.), вы можете использовать этот скрипт для автоматизации генерации строковых ресурсов Android .

ПроГард

Многие системы сборки Android используют ProGuard для сборки в режиме Release, чтобы уменьшить размер приложений и защитить исходный код Java.

Если вы используете ProGuard, вам потребуется добавить в конфигурацию ProGuard файлы из libs/android/*.pro , соответствующие используемым вами библиотекам Firebase C++.

Например, если вы используете Google Analytics в Gradle, ваш файл build.gradle будет выглядеть следующим образом:

android {
  // ...
  buildTypes {
    release {
      minifyEnabled true
      proguardFile getDefaultProguardFile('your-project-proguard-config.txt')
      proguardFile file(project.ext.your_local_firebase_sdk_dir + "/libs/android/app.pro")
      proguardFile file(project.ext.your_local_firebase_sdk_dir + "/libs/android/analytics.pro")
      // ...  and so on, for each Firebase C++ library that you're using
    }
  }
}

Требования к сервисам Google Play

Большинство библиотек Firebase C++ требуют наличия сервисов Google Play на Android-устройстве клиента. Если библиотека Firebase C++ возвращает kInitResultFailedMissingDependency при инициализации, это означает, что сервисы Google Play недоступны на устройстве клиента (то есть их необходимо обновить, повторно активировать, исправить разрешения и т. д.). Библиотека Firebase не может быть использована, пока ситуация на устройстве клиента не будет исправлена.

Вы можете выяснить, почему сервисы Google Play недоступны на устройстве клиента (и попытаться это исправить), используя функции из файла google_play_services/availability.h .

В таблице ниже указано, требуется ли наличие сервисов Google Play на клиентском устройстве для каждого поддерживаемого продукта Firebase.

Библиотека Firebase на C++ Требуются ли сервисы Google Play на клиентском устройстве?
AdMob Не требуется (обычно)
Analytics Не требуется
Authentication Необходимый
Cloud Firestore Необходимый
Cloud Functions Необходимый
Cloud Messaging Необходимый
Cloud Storage Необходимый
Dynamic Links Необходимый
Realtime Database Необходимый
Remote Config Необходимый

Сервисы AdMob и Google Play

Most versions of the Google Mobile Ads SDK for Android can work properly without Google Play services on the client device. However, if you're using the com.google.android.gms:play-services-ads-lite dependency, instead of the standard com.google.firebase:firebase-ads dependency listed above, Google Play services is required .

При инициализации AdMob kInitResultFailedMissingDependency вернет значение только в том случае, если выполняются оба следующих условия:

  • Сервисы Google Play недоступны на клиентском устройстве.
  • You're using com.google.android.gms:play-services-ads-lite .

Настройка рабочего процесса на рабочем столе ( бета-версия )

When you're creating a game, it's often much easier to test your game on desktop platforms first, then deploy and test on mobile devices later in development. To support this workflow, we provide a subset of the Firebase C++ SDKs which can run on Windows, macOS, Linux, and from within the C++ editor.

  1. Для рабочих процессов на настольных компьютерах необходимо выполнить следующие действия:

    1. Настройте свой проект C++ для работы с CMake.
    2. Создайте проект Firebase.
    3. Зарегистрируйте свое приложение (iOS или Android) в Firebase.
    4. Добавьте файл конфигурации Firebase для мобильной платформы.
  2. Создайте настольную версию файла конфигурации Firebase:

    • If you added the Android google-services.json file — When you run your app, Firebase locates this mobile file, then automatically generates a desktop Firebase config file ( google-services-desktop.json ).

    • If you added the iOS GoogleService-Info.plist file — Before you run your app, you need to convert this mobile file to a desktop Firebase config file. To convert the file, run the following command from the same directory as your GoogleService-Info.plist file:

      generate_xml_from_google_services_json.py --plist -i GoogleService-Info.plist

    Этот конфигурационный файл для настольных компьютеров содержит идентификатор проекта C++, который вы указали в процессе настройки консоли Firebase . Подробнее о конфигурационных файлах можно узнать в разделе «Понимание проектов Firebase» .

  3. Добавьте SDK Firebase в свой проект на C++.

    Приведенные ниже шаги служат примером того, как добавить любой поддерживаемый продукт Firebase в ваш проект C++. В этом примере мы рассмотрим добавление Firebase Authentication и Firebase Realtime Database .

    1. Set your FIREBASE_CPP_SDK_DIR environment variable to the location of the unzipped Firebase C++ SDK.

    2. В файл CMakeLists.txt вашего проекта добавьте следующее содержимое, включая библиотеки для продуктов Firebase, которые вы хотите использовать. Например, чтобы использовать Firebase Authentication и Firebase Realtime Database :

      # Add Firebase libraries to the target using the function from the SDK.
      add_subdirectory(${FIREBASE_CPP_SDK_DIR} bin/ EXCLUDE_FROM_ALL)
      
      # The Firebase C++ library `firebase_app` is required,
      # and it must always be listed last.
      
      # Add the Firebase SDKs for the products you want to use in your app
      # For example, to use Firebase Authentication and Firebase Realtime Database
      set(firebase_libs firebase_auth firebase_database firebase_app)
      target_link_libraries(${target_name} "${firebase_libs}")
  4. Запустите ваше приложение на C++.

Доступные библиотеки (для настольных компьютеров)

В состав Firebase C++ SDK входит поддержка рабочих процессов для настольных приложений, позволяющая использовать определенные части Firebase в автономных сборках для настольных приложений под управлением Windows, macOS и Linux.

Продукт Firebase Ссылки на библиотеки (с использованием CMake)
App Check firebase_app_check
(обязательно) firebase_app
Authentication firebase_auth
(обязательно) firebase_app
Cloud Firestore firebase_firestore
firebase_auth
firebase_app
Cloud Functions firebase_functions
(обязательно) firebase_app
Cloud Storage firebase_storage
(обязательно) firebase_app
Realtime Database firebase_database
(обязательно) firebase_app
Remote Config firebase_remote_config
(обязательно) firebase_app

Firebase provides the remaining desktop libraries as stub (non-functional) implementations for convenience when building for Windows, macOS, and Linux. Therefore, you don't need to conditionally compile code to target the desktop.

Настольная версия Realtime Database

SDK Realtime Database для настольных компьютеров использует REST для доступа к вашей базе данных, поэтому вам необходимо объявить индексы, которые вы используете с Query::OrderByChild() на настольной версии, иначе ваши обработчики событий будут работать некорректно.

Дополнительная информация по настройке рабочего стола

библиотеки Windows

Для Windows версии библиотек предоставляются на основе следующих критериев:

  • Платформа сборки: 32-битный (x86) и 64-битный (x64) режимы
  • Среда выполнения Windows: Многопоточность / MT против многопоточной DLL / MD
  • Цель: Релиз против отладки

Note that the following libraries were tested using Visual Studio 2015 and 2017.

При разработке настольных приложений на C++ для Windows необходимо подключить к проекту следующие библиотеки Windows SDK. Для получения дополнительной информации обратитесь к документации вашего компилятора.

Библиотека Firebase на C++ Зависимости библиотеки Windows SDK
App Check advapi32, ws2_32, crypt32
Authentication advapi32, ws2_32, crypt32
Cloud Firestore advapi32, ws2_32, crypt32, rpcrt4, ole32, shell32
Cloud Functions advapi32, ws2_32, crypt32, rpcrt4, ole32
Cloud Storage advapi32, ws2_32, crypt32
Realtime Database advapi32, ws2_32, crypt32, iphlpapi, psapi, userenv
Remote Config advapi32, ws2_32, crypt32, rpcrt4, ole32

библиотеки macOS

For macOS (Darwin), library versions are provided for the 64-bit (x86_64) platform. Frameworks are also provided for your convenience.

Обратите внимание, что библиотеки macOS были протестированы с использованием Xcode 26.2.

When building C++ desktop apps on macOS, link the following to your project:

  • библиотека системы pthread
  • Системная платформа CoreFoundation для macOS
  • Foundation системной структуры macOS
  • Системная структура Security macOS
  • Системная структура GSS macOS
  • Системная структура Kerberos для macOS
  • SystemConfiguration macOS

Для получения более подробной информации обратитесь к документации вашего компилятора.

библиотеки Linux

Для Linux доступны версии библиотеки для 32-битных (i386) и 64-битных (x86_64) платформ.

Обратите внимание, что тестирование библиотек Linux проводилось с использованием GCC 4.8.0, GCC 7.2.0 и Clang 5.0 на Ubuntu.

When building C++ desktop apps on Linux, link the pthread system library to your project. Consult your compiler documentation for more information. If you're building with GCC 5 or later, define -D_GLIBCXX_USE_CXX11_ABI=0 .

Следующие шаги