firebase 实时数据库查询数据仅适用于登录用户

firebase realtime database query data works only for logged in user

我有以下安全规则:

    {
      "rules": {
        "users": {
          ".read" : true,
          "$user_id": {
            ".read": true,
            ".write": "auth != null && $user_id === auth.uid"
          }
        }
      }
    }

我的数据如下:

    {
    "users" : {
    "JIZW3KswDDMggo9U1WwCoIamHaU2" : {
      "-L8s34CZsCgodNxgF09G" : {
        "email" : "lmn@yahoo.co.in",
        "isAdmin" : true,
        "name" : "Mannu Sharma",
      },
"UKtLdQzPdWa2KJ10iXrjuV80JSd2" : {
      "-L8LTf95dxqQdjYHhFDB" : {
        "email" : "pqr@gmail.com",
        "name" : "Neeti Singhal"
      }
    },
    "YQCXFjnU8jaXR9xUXIgknp18Z3A3" : {
      "-L8TQTFiGLEuxCTbbrQ7" : {
        "email" : "abcd@gmail.com",
        "name" : "John Teslie",

      }
    }
    }

我的angularfire2查询数据的代码是:

getUserByEmail(email:string){
    console.log("start of getUserByEmail with email:" + email)
    return new Promise((resolve, reject) =>
      {

        this.db.list("/users", 
          ref => ref.orderByChild('email').equalTo(email)
        ).valueChanges().subscribe(
          res => {
            console.log('response:' + JSON.stringify(res))
            resolve(res)
          },
          err => {
            console.log(err)
            reject(err)
          }
        )
      })
  }

我已经实现了使用 facebook 登录。因此,当我使用我的电子邮件 abcd@gmail.com 登录并进行搜索时 returns 我的记录。但是任何其他搜索都不起作用。

据我了解,我的安全规则允许任何人查询用户数据。那么我缺少什么?

您的数据是双重嵌套的:您有 /users/$uid/$pushId。不需要最后一个级别,这意味着您无法通过 email 查询用户。有关此一般情况的更多信息,请参阅 Firebase Query Double Nested.

但在这种情况下,解决方法非常简单:我认为您不需要 JSON 中带有推送 ID (-L....) 的关卡。您可能通过调用 push() 添加用户数据,这不是必需的。删除对 push() 的调用,可能使用 set() 代替它,并且您应该在 JSON 树中失去那个额外的级别。随着该级别的消失,您可以通过每个用户的 email 属性 查询 /users