Swift + Firebase安全无法正常工作

Jam*_*esG 7 ios firebase firebase-security swift firebase-realtime-database

我在Firebase控制台中创建了两个用户,两者都有不同的用户名和电子邮件地址.

我希望他们能够将他们的分数存储在数据库中.这是结构:

AppName
  - GameStats
    - DBW9WQEs2sQn9CuPTE9t7Q1qWSz2
      - Score : 0986
    - Li75C2BYW7bQnKqMmrqLAZ67HUy4
      - Score : 44131
Run Code Online (Sandbox Code Playgroud)

要访问此值并保持同步,我使用此:

let baseRef = FIRDatabase.database().reference(withPath: "GameStats/" + user.uid + "")
let scoreRef = scoreRef.child("Score")

scoreRef.observe(.value, with: { snapshot in
   print(snapshot.value)
})
Run Code Online (Sandbox Code Playgroud)

我想测试这两个用户是否可以访问其他用户的其他信息.我改变了行,以包括其他user.uid如此:

let baseRef = FIRDatabase.database().reference(withPath: "GameStats/Li75C2BYW7bQnKqMmrqLAZ67HUy4")

// Logged in User: DBW9WQEs2sQn9CuPTE9t7Q1qWSz2
Run Code Online (Sandbox Code Playgroud)

由于某种原因,它输出:

Optional(44131)
Run Code Online (Sandbox Code Playgroud)

如果我更改数据库中的值,它会自动将值更新为我放置的值.

这是错误的用户,由于某种原因,它可以访问它.

这些是我的规则:

  {
  "rules": {
    ".read": "auth != null",
    ".write": "auth != null",
      "GameStats": {
         "$user_id": {
         ".write": "auth != null && auth.uid === $user_id && auth.provider === 'password'",
         ".read": "auth != null && auth.uid === $user_id && auth.provider === 'password'"
      }
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

为什么应用程序允许一个用户读取另一个用户数据?如何限制访问权限以便用户只能访问其用户ID下的数据?

正如@M_G建议的那样,我.write从父母那里拿出来了.read.所以我现在的规则是:

  {
  "rules": {
    // ".read": "auth != null",
    // ".write": "auth != null",
      "GameStats": {
         "$user_id": {
         ".write": "auth != null && auth.uid === $user_id && auth.provider === 'password'",
         ".read": "auth != null && auth.uid === $user_id && auth.provider === 'password'"
       }
     }
  }
}
Run Code Online (Sandbox Code Playgroud)

我现在得到这个输出:

[FirebaseDatabase] setValue: or removeValue: at /GameStats/DBW9WQEs2sQn9CuPTE9t7Q1qWSz2 failed: permission_denied - This is for the correct user too. I get this error if wrong user also. 
Run Code Online (Sandbox Code Playgroud)

Muz*_*fer 3

Firebase 文档是错误的(目前)。在 Firebase 控制台中,打开规则模拟器。目前没有“密码”选项,我认为这是一个错误。

如果您没有使用多重身份验证或多重身份验证在您的项目中并不重要,请不要按照您的规则使用提供程序。否则,您可以测试此密码身份验证规则:

".write": "auth != null && auth.uid === $user_id && auth.token.firebase.identities.email !== null"
Run Code Online (Sandbox Code Playgroud)