本頁面由 Cloud Translation API 翻譯而成。
Switch to English

使用JavaScript匿名通過Firebase進行身份驗證

您可以使用Firebase身份驗證來創建並使用臨時匿名帳戶向Firebase進行身份驗證。這些臨時的匿名帳戶可用於允許尚未註冊您的應用的用戶使用受安全規則保護的數據。如果匿名用戶決定註冊您的應用程序,則可以將其登錄憑據鏈接到匿名帳戶,以便他們可以在以後的會話中繼續使用其受保護的數據。

在你開始之前

  1. 將Firebase添加到您的JavaScript項目
  2. 如果您尚未將應用程序連接到Firebase項目,請從Firebase控制台進行
  3. 啟用匿名身份驗證:
    1. Firebase控制台中 ,打開“ 身份驗證”部分。
    2. 在“ 登錄方法”頁面上,啟用“ 匿名”登錄方法。

使用Firebase匿名進行身份驗證

當註銷用戶使用需要通過Firebase進行身份驗證的應用程序功能時,請完成以下步驟以匿名方式登錄該用戶:

  1. 調用signInAnonymously方法:
    firebase.auth().signInAnonymously().catch(function(error) {
      // Handle Errors here.
      var errorCode = error.code;
      var errorMessage = error.message;
      // ...
    });
    
    這也是捕獲和處理錯誤的地方。有關錯誤代碼的列表,請查看Auth Reference Docs
  2. 如果signInAnonymously方法正確完成,則將觸發在onAuthStateChanged註冊的觀察者,您可以從User像中獲取匿名用戶的帳戶數據:
    firebase.auth().onAuthStateChanged(function(user) {
      if (user) {
        // User is signed in.
        var isAnonymous = user.isAnonymous;
        var uid = user.uid;
        // ...
      } else {
        // User is signed out.
        // ...
      }
      // ...
    });

將匿名帳戶轉換為永久帳戶

當匿名用戶註冊您的應用程序時,您可能希望允許他們繼續使用其新帳戶進行工作-例如,您可能希望使用戶添加到購物車中的項目在他們註冊後可以在新帳戶中使用帳戶的購物車。為此,請完成以下步驟:

  1. 用戶註冊後,請完成但不包括調用Auth.signInWith方法之一的用戶身份驗證提供程序的登錄流程。例如,獲取用戶的Google ID令牌,Facebook訪問令牌或電子郵件地址和密碼。
  2. 獲取新身份驗證提供程序的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);
    
  3. AuthCredentialAuthCredential傳遞給登錄用戶的link方法:

    auth.currentUser.linkWithCredential(credential)
      .then(function(usercred) {
        var user = usercred.user;
        console.log("Anonymous account successfully upgraded", user);
      }).catch(function(error) {
        console.log("Error upgrading anonymous account", error);
      });

如果link調用成功,則用戶的新帳戶可以訪問匿名帳戶的Firebase數據。

下一步

現在,用戶可以通過Firebase進行身份驗證,您可以使用Firebase規則控制對Firebase數據庫中數據的訪問。