首页 文章

使用localId / idToken(而不是电子邮件/密码)进行Firebase身份验证

提问于
浏览
0

在我的应用程序中,当用户登录时,我使用firebase.auth根据用户键入的电子邮件/密码对用户进行身份验证:

firebase.auth().signInWithEmailAndPassword(userInputs.email.value, userInputs.password.value)

然后我将它调度到redux状态,并在本地存储上设置接收到的localId和idToken:

localStorage.setItem('token', response.user.qa);
localStorage.setItem('localId', response.user.uid);

当用户关闭应用程序窗口然后稍后重新打开应用程序时,localId和idToken仍然在localstorage中设置,但要重新进行身份验证,我需要提供电子邮件和密码 . 是否可以使用localId / idToken进行身份验证,还是应该在localStorage上保存电子邮件/密码而不是保存两个令牌?

在检查用户是否经过身份验证时:

var user = firebase.auth().currentUser;
console.log(user);

我得到'空' . 看来即使我已经拥有localId,我必须登录,如果没有登录,我就无法访问数据库 .

此外,显然我的数据库规则仅授予经过身份验证的用户访问数据库的权限:

{
  "rules": {
    ".read": "auth != null",
    ".write": "auth != null"
  }
}

提前致谢!

1 回答

  • 1

    您不必将电子邮件和密码存储在localstorage中 . Firebase库会自动在本地保留身份验证信息 .

    你得到 null 的原因是你试图用同步代码获取用户信息 . 这意味着您正试图在firebase库的初始化之前获取用户 .

    firebase.auth().currentUser; // <= synchronous
    

    以下代码以异步方式运行,您可以在firebase库初始化后获取用户 .

    firebase.auth().onAuthStateChanged(function(user) {
      if (user) {
        // User is signed in.
      } else {
        // No user is signed in.
      }
    });
    

相关问题