Firebase Angularfire2检查数据库中是否存在用户

前端之家收集整理的这篇文章主要介绍了Firebase Angularfire2检查数据库中是否存在用户前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个包含2个对象的数据库.它看起来像这样:
users
    - KEY
        login: "xexe"
        password: "123"

    - KEY
        login: "dede"
        password: "123"@H_403_3@ 
 

现在我正在检查数据库中是否存在用户

constructor(private af: AngularFire) {
    this.users = af.database.list('/users');
  }

  registerUser(login: string,password: string) {
    this.af.database.list('/users',{
      query: {
        orderByChild: 'login',equalTo: login
      }
    }).subscribe(response => {
      if(response.length === 0) {
        console.log("User does not exist");
        //here i will add a user
      } else {
        console.log("Users exists");
      }
    })
  }@H_403_3@ 
 

有什么问题?

让我们尝试使用“dede”登录注册用户(用户应该存在)

当我第一次单击提交按钮时,控制台显示
用户存在 – >好吧,那很好.

问题是当我第二次点击提交时(没有刷新网页)

然后console.log向我显示了两条消息

User does not exist
User exists@H_403_3@ 
 

这将为新用户添加不应该做的事情.为什么第二次订阅函数遍历每一行?怎么解决

解决方法

您可以构建数据以使用登录属性作为KEY,而不是使用查询.
{
  "users": {
    "dede": {
      "login": "dede","password": "Do not store passwords :)"
    },"xexe": {
      "login": "xexe"
    }
  }
}@H_403_3@ 
 

现在,您可以创建对此位置的引用,并检查该对象是否存在.

registerUser(login: string,password: string) {
  const user = this.af.database.object(`users/${login}`);
  user.subscribe(data => {
    if(data.$value !== null) {
      console.log('User does not exist');
    } else {
      console.log('User does exist');
    }
  });
}@H_403_3@
原文链接:https://www.f2er.com/mssql/74948.html

猜你在找的MsSQL相关文章