您可以使用Firebase身份驗證來創建並使用臨時匿名帳戶向Firebase進行身份驗證。這些臨時的匿名帳戶可用於允許尚未註冊您的應用的用戶使用受安全規則保護的數據。如果匿名用戶決定註冊您的應用,則可以將其登錄憑據鏈接到匿名帳戶,以便他們可以在以後的會話中繼續使用其受保護的數據。
在你開始之前
- 將Firebase添加到您的C ++項目。
- 如果您尚未將應用程序連接到Firebase項目,請從Firebase控制台進行。
- 啟用匿名身份驗證:
- 在Firebase控制台中,打開“身份驗證”部分。
- 在“登錄方法”頁面上,啟用“匿名”登錄方法。
使用Firebase匿名進行身份驗證
當註銷用戶使用需要通過Firebase進行身份驗證的應用程序功能時,請完成以下步驟以匿名方式登錄該用戶:
Auth
類是所有API調用的網關。- 添加Auth和App頭文件:
#include "firebase/app.h" #include "firebase/auth.h"
- 在初始化代碼中,創建一個
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__)
- 為您的
firebase::App
獲取firebase::auth::Auth
類。App
和Auth
之間存在一對一的映射。firebase::auth::Auth* auth = firebase::auth::Auth::GetAuth(app);
Auth::SignInAnonymously
。 firebase::Future<firebase::auth::User*> result = auth->SignInAnonymously();
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的回調。
將匿名帳戶轉換為永久帳戶
當匿名用戶註冊您的應用程序時,您可能希望允許他們繼續使用其新帳戶進行工作-例如,您可能希望使用戶添加到購物車中的項目在他們註冊後可以在新帳戶中使用帳戶的購物車。為此,請完成以下步驟:
- 當用戶註冊時,請完成但不包括調用
Auth::SignInWith
方法之一的用戶身份驗證提供程序的登錄流程。例如,獲取用戶的Google ID令牌,Facebook訪問令牌或電子郵件地址和密碼。 獲取新身份驗證提供程序的
Google登錄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);
將
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數據。
下一步
現在,用戶可以通過Firebase進行身份驗證,您可以使用Firebase規則控制他們對Firebase數據庫中數據的訪問。