java – 检查Firebase数据库中是否存在特定值

我正在使用Firebase实时数据库制作Android应用程序.当新用户在我的应用上注册时,该用户的数据将保存在Firebase数据库中.

用户必须提供以下详细信息才能注册:

>全名
>电子邮件
>用户名
>密码

数据库结构

enter image description here

每当新用户尝试注册时,我必须确保每个用户的用户名都是唯一的,因此我检查数据库是否用户输入的用户名已经存在于数据库中.

为此,我编写了以下方法:

private boolean usernameExists(String username) {
     DatabaseReference fdbRefer = FirebaseDatabase.getInstance().getReference("Users/"+username);
     return (fdbRefer != null);
}

我在这个方法背后的逻辑是,如果getReference方法找不到对指定路径的引用,它将返回null,以便我可以返回fdbRefer是否为null.如果fdbRefer为null,则表示数据库中不存在用户名.

问题

此方法的问题在于,无论输入的用户名是否存在于数据库中,它始终返回true.这让我相信fdbRefer永远不会为空.

这让我想到了我的问题……

当getReference方法在firebase数据库中找不到指定的路径时,返回的内容是什么?检查用户名是否已存在于数据库中的正确方法是什么?

最佳答案
要检查用户是否存在,请使用以下代码:

DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();
DatabaseReference userNameRef = rootRef.child("Users").child("Nick123");
ValueEventListener eventListener = new ValueEventListener() {
    @Override
    public void onDataChange(DataSnapshot dataSnapshot) {
        if(!dataSnapshot.exists()) {
            //create new user
        }
    }

    @Override
    public void onCancelled(DatabaseError databaseError) {
        Log.d(TAG, databaseError.getMessage()); //Don't ignore errors!
    }
};
userNameRef.addListenerForSingleValueEvent(eventListener);

您还可以使用Query来实现相同的功能:

DatabaseReference rootRef = FirebaseDatabase.getInstance().getReference();
Query query = rootRef.child("Users").orderByChild("userName").equalTo("Nick123");
query.addValueEventListener(/* ... */);

这是循环遍历整个Users节点的另一种方法,但不仅仅是使用对单个用户的直接引用.当您使用uid而不是用户名(如您现在所做的那样)作为唯一标识符时,更有可能使用此选项.因此,如果您的数据库结构可能与此类似:

Firebase-root
   |
   --- Users
        |
        --- uid
             |
             --- userName: "Test User"
             |
             --- emailAddress: "user@email.com"

第二种解决方案是推荐的解决方案.

还有另一种解决方案,它涉及您创建另一个名为userNames的节点,您只能在其中保存唯一的用户名.请在下面找到相应的安全规则:

"Users": {
  "$uid": {
    ".write": "auth !== null && auth.uid === $uid",
    ".read": "auth !== null && auth.provider === 'password'",
    "userName": {
      ".validate": "
        !root.child('userNames').child(newData.val()).exists() ||
        root.child('userNames').child(newData.val()).val() == $uid"
    }
  }
}

但由于在这种情况下,您的用户名已经是节点的名称,我建议您继续使用第一个节点.

转载注明原文:java – 检查Firebase数据库中是否存在特定值 - 代码日志