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

elz*_*zoy 6 firebase firebase-realtime-database angularfire2 angular

我有一个包含2个对象的数据库.它看起来像这样:

users
    - KEY
        login: "xexe"
        password: "123"

    - KEY
        login: "dede"
        password: "123"
Run Code Online (Sandbox Code Playgroud)

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

  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");
      }
    })
  }
Run Code Online (Sandbox Code Playgroud)

有什么问题?

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

当我第一次单击提交按钮时,控制台显示: Users exists- >嗯,这很好.

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

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

User does not exist
User exists
Run Code Online (Sandbox Code Playgroud)

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

Dav*_*ast 9

您可以构建数据以使用login属性,而不是使用查询KEY.

{
  "users": {
    "dede": {
      "login": "dede",
      "password": "Do not store passwords :)"
    },
    "xexe": {
      "login": "xexe"
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

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

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');
    }
  });
}
Run Code Online (Sandbox Code Playgroud)

  • 你也可以查看`data.$ exists()`,它返回一个布尔值. (2认同)