您可以使用 Firebase 身份驗證來創建和使用臨時匿名帳戶來通過 Firebase 進行身份驗證。這些臨時匿名帳戶可用於允許尚未註冊您的應用的用戶使用受安全規則保護的數據。如果匿名用戶決定註冊您的應用程序,您可以將他們的登錄憑據鏈接到匿名帳戶,以便他們可以在以後的會話中繼續使用受保護的數據。
在你開始之前
- 將 Firebase 添加到您的 JavaScript 項目中。
- 如果您尚未將應用連接到 Firebase 項目,請從Firebase 控制台執行此操作。
- 啟用匿名身份驗證:
- 在Firebase 控制台中,打開Auth部分。
- 在登錄方法頁面上,啟用匿名登錄方法。
- 可選:如果您已使用 Identity Platform 將項目升級到 Firebase 身份驗證,則可以啟用自動清理。啟用此設置後,超過 30 天的匿名帳戶將被自動刪除。在啟用自動清理的項目中,匿名身份驗證將不再計入使用限製或計費配額。請參閱自動清理。
匿名使用 Firebase 進行身份驗證
當已註銷的用戶使用需要通過 Firebase 進行身份驗證的應用功能時,請完成以下步驟以匿名方式登錄該用戶:
- 調用
signInAnonymously
方法:這也是您可以捕獲和處理錯誤的地方。有關錯誤代碼的列表,請查看Auth Reference Docs 。Web version 9
import { getAuth, signInAnonymously } from "firebase/auth"; const auth = getAuth(); signInAnonymously(auth) .then(() => { // Signed in.. }) .catch((error) => { const errorCode = error.code; const errorMessage = error.message; // ... });
Web version 8
firebase.auth().signInAnonymously() .then(() => { // Signed in.. }) .catch((error) => { var errorCode = error.code; var errorMessage = error.message; // ... });
- 如果
signInAnonymously
方法完成沒有錯誤,註冊在onAuthStateChanged
中的觀察者將觸發,您可以從User
對像中獲取匿名用戶的帳戶數據:Web version 9
import { getAuth, onAuthStateChanged } from "firebase/auth"; const auth = getAuth(); onAuthStateChanged(auth, (user) => { if (user) { // User is signed in, see docs for a list of available properties // https://firebase.google.com/docs/reference/js/firebase.User const uid = user.uid; // ... } else { // User is signed out // ... } });
Web version 8
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
:谷歌登錄
Web version 9
import { GoogleAuthProvider } from "firebase/auth"; const credential = GoogleAuthProvider.credential( googleUser.getAuthResponse().id_token);
Web version 8
var credential = firebase.auth.GoogleAuthProvider.credential( googleUser.getAuthResponse().id_token);
Facebook登入
Web version 9
import { FacebookAuthProvider } from "firebase/auth"; const credential = FacebookAuthProvider.credential( response.authResponse.accessToken);
Web version 8
var credential = firebase.auth.FacebookAuthProvider.credential( response.authResponse.accessToken);
電子郵件密碼登錄
Web version 9
import { EmailAuthProvider } from "firebase/auth"; const credential = EmailAuthProvider.credential(email, password);
Web version 8
var credential = firebase.auth.EmailAuthProvider.credential(email, password);
將
AuthCredential
對像傳遞給登錄用戶的link
方法:Web version 9
import { getAuth, linkWithCredential } from "firebase/auth"; const auth = getAuth(); linkWithCredential(auth.currentUser, credential) .then((usercred) => { const user = usercred.user; console.log("Anonymous account successfully upgraded", user); }).catch((error) => { console.log("Error upgrading anonymous account", error); });
Web version 8
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 數據。
自動清理
如果您已使用 Identity Platform 將項目升級到 Firebase 身份驗證,則可以在 Firebase 控制台中啟用自動清理。當您啟用此功能時,Firebase 會自動刪除超過 30 天的匿名帳戶。在啟用自動清理的項目中,匿名身份驗證將不計入使用限製或計費配額。
- 在啟用自動清理後創建的任何匿名帳戶可能會在創建後 30 天后的任何時間自動刪除。
- 在啟用自動清理之前創建的匿名帳戶將有資格在啟用自動清理後 30 天開始自動刪除。
- 如果您關閉自動清理,任何預定被刪除的匿名帳戶將保持預定被刪除。這些帳戶不計入使用限製或計費配額。
- 如果您通過將匿名帳戶鏈接到任何登錄方法來“升級”匿名帳戶,則該帳戶不會被自動刪除。
如果您想在啟用此功能之前查看有多少用戶會受到影響,並且您已將項目升級到使用 Identity Platform 的 Firebase 身份驗證,則可以在Cloud Logging中按is_anon
進行過濾。
下一步
現在用戶可以使用 Firebase 進行身份驗證,您可以使用Firebase 規則控制他們對 Firebase 數據庫中數據的訪問。