Project Icon

firebase-cpp-sdk

跨平台开发库集成多种云服务

firebase-cpp-sdk是Firebase提供的开源C++ SDK,支持Android、iOS和桌面平台开发。该SDK集成了分析、身份验证、实时数据库、动态链接等多种Firebase服务。采用CMake构建系统,便于跨平台开发,并提供详细的构建指南和示例。开发者可将Firebase功能轻松集成到C++项目中,提升应用开发效率和用户体验。

Firebase C++ 开源开发

本仓库包含 Firebase C++ SDK 源代码,支持 Android、iOS 和桌面平台。它包括以下 Firebase 库:


Firebase 是一个应用开发平台,提供工具帮助你构建、增长和变现你的应用。关于 Firebase 的更多信息可以在这里找到。

  • 关于 Firebase C++ SDK 的更多信息可以在这里找到
  • 如何使用 Firebase C++ SDK 的示例可以在这里找到

Github 仓库大小

目录

  1. 入门
  2. 先决条件
  3. 构建
  4. 在项目中包含
  5. 贡献指南
  6. 许可证

入门

你可以使用以下命令克隆仓库:

git clone https://github.com/firebase/firebase-cpp-sdk.git

先决条件

以下先决条件适用于所有平台。请确保根据需要将任何目录添加到你的 PATH 中。

注意:安装 Python 后,你可以使用以下命令安装所需的包:

  • python3 -m ensurepip --default-pip
  • python3 -m pip install --user absl-py

桌面平台的先决条件

在为桌面平台构建库时,需要以下先决条件。

  • OpenSSL,用于实时数据库和 Cloud Firestore

Windows 的先决条件

可以通过谷歌搜索找到 OpenSSL 的预构建包,如果 CMake 无法找到安装路径,请使用命令行选项 -DOPENSSL_ROOT_DIR=[Open SSL Dir]

Mac 的先决条件

可以使用 Homebrew 安装所需的依赖项:

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
source $HOME/.rvm/scripts/rvm
brew install cmake python3
sudo chown -R $(whoami) /usr/local

Android 的先决条件

在为 Android 构建库时,需要以下先决条件。

  • Android SDK、Android NDK 和用于 Android 的 CMake(推荐 3.10.2 版本)
    • 这里下载 sdkmanager(独立或作为 Android Studio 的一部分)
    • 按照这些说明安装必要的构建工具
  • (仅限 Windows)Strings(来自 Microsoft Sysinternals)

    重要 - Strings EULA
    在构建过程中使用 Strings 之前,你需要先从命令行运行一次 Strings 以接受 EULA。

注意,我们包含了 Gradle 包装器,如果使用它,将为你获取必要版本的 Gradle。

iOS/tvOS 的先决条件

在为 iOS 或 tvOS 构建库时,需要以下先决条件。

构建

使用 CMake 构建

构建使用 CMake 生成必要的构建文件,并支持源外构建。 以下 CMake 目标可用于构建和链接:

功能CMake 目标
App(基础库)firebase_app
Google Analytics for Firebasefirebase_analytics
Firebase 身份验证firebase_auth
Firebase 实时数据库firebase_database
Firebase 动态链接firebase_dynamic_links
Cloud Firestorefirebase_firestore
Cloud Functions for Firebasefirebase_functions
Firebase 邀请firebase_invites
Firebase 云消息传递firebase_messaging
Firebase 远程配置firebase_remote_config
Cloud Storage for Firebasefirebase_storage

例如,要构建 Analytics 库,你可以运行以下命令:

mkdir desktop_build && cd desktop_build
cmake ..
cmake --build . --target firebase_analytics

请注意,你可以在配置步骤中提供不同的生成器,例如,要为 Visual Studio 2017 生成项目,你可以运行:

cmake -G "Visual Studio 15 2017" ..

有关生成器的更多信息,请访问 https://cmake.org/cmake/help/latest/manual/cmake-generators.7.html

默认情况下,在构建 SDK 时,CMake 过程会下载构建所需的任何第三方依赖项。这个逻辑在 cmake/external_rules.cmake 中,以及随附的 cmake/external/CMakeLists.txt 中。如果你想为这些依赖项提供自己的目录,可以覆盖 [[dependency_name]]_SOURCE_DIR[[dependency_name]]_BINARY_DIR。如果未提供二进制目录,它将默认为给定的源目录,并附加 -build

例如,要提供自定义的 flatbuffer 目录,你可以运行:

cmake -DFLATBUFFERS_SOURCE_DIR=/tmp/flatbuffers ..

二进制目录将自动设置为 /tmp/flatbuffers-build

目前,可以通过这种方式提供的第三方库有:

CURL
FLATBUFFERS
LIBUV
NANOPB
UWEBSOCKETS
ZLIB

使用 CMake 为 iOS 构建

Firebase C++ SDK 附带了一个 CMake 配置文件,用于为 iOS 平台构建库,cmake/toolchains/ios.cmake。要使用它构建,在运行 CMake 配置时,通过 CMAKE_TOOLCHAIN_FILE 定义传入它。例如,要为 iOS 构建 Auth 库,你可以运行以下命令:

mkdir ios_build && cd ios_build
cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/ios.cmake ..
cmake --build . --target firebase_auth

使用 CMake 为 tvOS 构建

Firebase C++ SDK 附带了一个 CMake 配置文件,用于为 tvOS 平台构建库,cmake/toolchains/apple.toolchain.cmake。要使用它构建,在运行 CMake 配置时,通过 CMAKE_TOOLCHAIN_FILE 定义传入它。例如,要为 tvOS 构建 Auth 库,你可以运行以下命令:

mkdir tvos_build && cd tvos_build
cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/toolchains/apple.toolchain.cmake -DPLATFORM=TVOS ..
cmake --build . --target firebase_auth

为 iOS 和 tvOS 构建 XCFrameworks

Firebase C++ SDK 附带了一个辅助 Python 脚本,用于构建同时适用于 iOS 和 tvOS 的 XCFrameworks。这很有帮助,因为我们可以在同一个 Xcode 项目中为 iOS 和 tvOS 目标使用相同的交付物。

# 安装先决条件(如 cocoapods)
./build_scripts/tvos/install_prereqs.sh
python3 scripts/gha/build_ios_tvos.py -s . -b ios_tvos_build

使用 Gradle 构建 Android 版本

在为 Android 构建 Firebase C++ SDK 时,使用 gradle 和 CMake 相结合来生成库文件。每个 Firebase 功能都是根目录下的一个独立 gradle 子项目。构建每个 Firebase 库的发布版本的 gradle 目标如下:

功能Gradle 目标
App (基础库):app:assembleRelease
Google Analytics for Firebase:analytics:assembleRelease
Firebase Authentication:auth:assembleRelease
Firebase Realtime Database:database:assembleRelease
Firebase Dynamic Links:dynamic_links:assembleRelease
Cloud Firestore:firestore:assembleRelease
Cloud Functions for Firebase:functions:assembleRelease
Firebase Invites:invites:assembleRelease
Firebase Cloud Messaging:messaging:assembleRelease
Firebase Remote Config:remote_config:assembleRelease
Cloud Storage for Firebase:storage:assembleRelease

例如,要构建 Analytics 库的发布版本,你可以在根目录下运行以下命令:

./gradlew :analytics:assembleRelease

Proguard 文件生成

请注意,作为构建过程的一部分,每个库都会生成一个应该包含在你的应用程序中的 proguard 文件。生成的文件位于每个库的构建目录中。例如,Analytics 的 proguard 文件会生成到 analytics/build/analytics.pro

测试

此仓库中的每个 Firebase SDK 都包含一系列单元测试。这些测试由 CI 系统构建和执行,以验证更改和拉取请求。

提供的 test_windows_x32.battest_windows_x64.battest_linux.shtest_mac_x64.sh 脚本分别在 Windows32、Windows64、Linux 和 MacOS 主机上通过 ctest 构建 SDK 并执行单元测试。这些脚本位于仓库的基目录中。

已知问题

  • Mac
    • 执行测试时,系统可能会要求你解锁 Mac OS 钥匙串。请输入你的钥匙串密码并选择始终允许。如果你仍然遇到重复的访问请求对话框,则必须手动解锁钥匙串,否则某些测试将失败。
      • 在 Mac 上打开钥匙串访问应用程序。
      • 钥匙串(左上角)下选择登录钥匙串。
      • 类别下选择密码作为类别(左下角),找到条目 not_a_real_project_id.{hashcode}。右键点击它。
      • 选择显示简介,选择访问控制并启用允许所有应用程序访问此项目单选按钮。
      • 重新运行测试。

许可证

本仓库的内容根据 Apache License, version 2.0 许可。

你对 Firebase 的使用受 Firebase 服务条款 的约束。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号