您可以使用Firebase身份驗證創建並使用臨時匿名帳戶向Firebase進行身份驗證。這些臨時的匿名帳戶可用於允許尚未註冊您的應用的用戶使用受安全規則保護的數據。如果匿名用戶決定註冊您的應用程序,則可以將其登錄憑據鏈接到匿名帳戶,以便他們可以在以後的會話中繼續使用其受保護的數據。
在你開始之前
- 將Firebase添加到您的JavaScript項目。
- 如果您尚未將應用程序連接到Firebase項目,請從Firebase控制台進行。
- 啟用匿名身份驗證:
- 在Firebase控制台中,打開“身份驗證”部分。
- 在“登錄方法”頁面上,啟用“匿名”登錄方法。
匿名通過Firebase進行身份驗證
當註銷用戶使用需要通過Firebase進行身份驗證的應用程序功能時,請完成以下步驟以匿名方式登錄該用戶:
- 調用
signInAnonymously
方法:firebase.auth().signInAnonymously() .then(() => { // Signed in.. }) .catch((error) => { var errorCode = error.code; var errorMessage = error.message; // ... });
這也是捕獲和處理錯誤的地方。有關錯誤代碼的列表,請查看Auth Reference Docs 。 - 如果
signInAnonymously
方法正確完成,則將觸發在onAuthStateChanged
註冊的觀察者,並且您可以從User
像中獲取匿名用戶的帳戶數據:firebase.auth().onAuthStateChanged((user) => { if (user) { // User is signed in, see docs for a list of available properties // https://firebase.google.com/docs/reference/js/firebase.User var uid = user.uid; // ... } else { // User is signed out // ... } });
將匿名帳戶轉換為永久帳戶
當匿名用戶註冊您的應用程序時,您可能希望允許他們繼續使用其新帳戶進行工作-例如,您可能希望使用戶添加到購物車中的項目在他們註冊後可以在新帳戶中使用帳戶的購物車。為此,請完成以下步驟:
- 用戶註冊後,請完成但不包括調用
Auth.signInWith
方法之一的用戶身份驗證提供程序的登錄流程。例如,獲取用戶的Google ID令牌,Facebook訪問令牌或電子郵件地址和密碼。 獲取新身份驗證提供程序的
AuthCredential
:Google登錄
var credential = firebase.auth.GoogleAuthProvider.credential( googleUser.getAuthResponse().id_token);
Facebook登入
var credential = firebase.auth.FacebookAuthProvider.credential( response.authResponse.accessToken);
電子郵件密碼登錄
var credential = firebase.auth.EmailAuthProvider.credential(email, password);
將
AuthCredential
對AuthCredential
傳遞給登錄用戶的link
方法:auth.currentUser.linkWithCredential(credential) .then((usercred) => { var user = usercred.user; console.log("Anonymous account successfully upgraded", user); }).catch((error) => { console.log("Error upgrading anonymous account", error); });
如果link
調用成功,則用戶的新帳戶可以訪問匿名帳戶的Firebase數據。
下一步
現在,用戶可以通過Firebase進行身份驗證,您可以使用Firebase規則控制他們對Firebase數據庫中數據的訪問。