Google 致力于为黑人社区推动种族平等。查看具体举措

使用 C++ 匿名通过 Firebase 进行身份验证

使用集合让一切井井有条 根据您的偏好保存内容并对其进行分类。

您可以使用 Firebase 身份验证来创建和使用临时匿名帐户来通过 Firebase 进行身份验证。这些临时匿名帐户可用于允许尚未注册您的应用的用户使用受安全规则保护的数据。如果匿名用户决定注册您的应用程序,您可以将他们的登录凭据链接到匿名帐户,以便他们可以在以后的会话中继续使用受保护的数据。

在你开始之前

  1. 将 Firebase 添加到您的 C++ 项目中。
  2. 如果您尚未将应用连接到 Firebase 项目,请从Firebase 控制台执行此操作。
  3. 启用匿名身份验证:
    1. Firebase 控制台中,打开Auth部分。
    2. 登录方法页面上,启用匿名登录方法。
    3. 可选:如果您已使用 Identity Platform 将项目升级到 Firebase 身份验证,则可以启用自动清理。启用此设置后,超过 30 天的匿名帐户将被自动删除。在启用自动清理的项目中,匿名身份验证将不再计入使用限制或计费配额。请参阅自动清理

匿名使用 Firebase 进行身份验证

当已注销的用户使用需要通过 Firebase 进行身份验证的应用功能时,请完成以下步骤以匿名方式登录该用户:

Auth类是所有 API 调用的网关。
  1. 添加 Auth 和 App 头文件:
    #include "firebase/app.h"
    #include "firebase/auth.h"
    
  2. 在您的初始化代码中,创建一个firebase::App类。
    #if defined(__ANDROID__)
      firebase::App* app =
          firebase::App::Create(firebase::AppOptions(), my_jni_env, my_activity);
    #else
      firebase::App* app = firebase::App::Create(firebase::AppOptions());
    #endif  // defined(__ANDROID__)
    
  3. 为您的firebase::App获取firebase::auth::Auth类。 AppAuth之间存在一对一的映射关系。
    firebase::auth::Auth* auth = firebase::auth::Auth::GetAuth(app);
    
  • 调用Auth::SignInAnonymously
    firebase::Future<firebase::auth::User*> result = auth->SignInAnonymously();
    
  • 如果您的程序有一个定期运行的更新循环(例如每秒 30 或 60 次),您可以使用Auth::SignInAnonymouslyLastResult每次更新检查一次结果:
    firebase::Future<firebase::auth::User*> result =
        auth->SignInAnonymouslyLastResult();
    if (result.status() == firebase::kFutureStatusComplete) {
      if (result.error() == firebase::auth::kAuthErrorNone) {
        firebase::auth::User* user = *result.result();
        printf("Sign in succeeded for `%s`\n", user->display_name().c_str());
      } else {
        printf("Sign in failed with error '%s'\n", result.error_message());
      }
    }
    
    或者,如果您的程序是事件驱动的,您可能更喜欢在 Future 上注册回调
  • 将匿名帐户转换为永久帐户

    当匿名用户注册您的应用程序时,您可能希望允许他们使用新帐户继续工作——例如,您可能希望让用户在注册之前添加到购物车中的商品在他们的新帐户中可用帐户的购物车。为此,请完成以下步骤:

    1. 当用户注册时,为用户的身份验证提供程序完成登录流程,直至但不包括调用Auth::SignInWith方法之一。例如,获取用户的 Google ID 令牌、Facebook 访问令牌或电子邮件地址和密码。
    2. 获取新身份验证提供程序的auth::Credential

      谷歌登录
      firebase::auth::Credential credential =
          firebase::auth::GoogleAuthProvider::GetCredential(google_id_token,
                                                            nullptr);
      
      Facebook 登录
      firebase::auth::Credential credential =
          firebase::auth::FacebookAuthProvider::GetCredential(access_token);
      
      电子邮件密码登录
      firebase::auth::Credential credential =
          firebase::auth::EmailAuthProvider::GetCredential(email, password);
      
    3. auth::Credential对象传递给登录用户的LinkWithCredential方法:

      // Link the new credential to the currently active user.
      firebase::auth::User* current_user = auth->current_user();
      firebase::Future<firebase::auth::User*> result =
          current_user->LinkWithCredential(credential);
      

    如果对LinkWithCredential的调用成功,则用户的新帐户可以访问匿名帐户的 Firebase 数据。

    自动清理

    如果您已使用 Identity Platform 将项目升级到 Firebase 身份验证,则可以在 Firebase 控制台中启用自动清理。当您启用此功能时,Firebase 会自动删除超过 30 天的匿名帐户。在启用自动清理的项目中,匿名身份验证将不计入使用限制或计费配额。

    • 在启用自动清理后创建的任何匿名帐户可能会在创建后 30 天后的任何时间自动删除。
    • 在启用自动清理之前创建的匿名帐户将有资格在启用自动清理后 30 天开始自动删除。
    • 如果您关闭自动清理,任何预定被删除的匿名帐户将保持预定被删除。这些帐户不计入使用限制或计费配额。
    • 如果您通过将匿名帐户链接到任何登录方法来“升级”匿名帐户,则该帐户不会被自动删除。

    如果您想在启用此功能之前查看有多少用户会受到影响,并且您已将项目升级到使用 Identity Platform 的 Firebase 身份验证,则可以在Cloud Logging中按is_anon进行过滤。

    下一步

    现在用户可以使用 Firebase 进行身份验证,您可以使用Firebase 规则控制他们对 Firebase 数据库中数据的访问。