当前位置: 首页 > 知识库问答 >
问题:

Firebase实时数据库安全规则(读写)

阙星渊
2023-03-14

好的,我有一个实时数据库连接到一个应用程序,直到今天规则(读写)都设置为真,一切都很好。。。。但每次有消息说

您的安全规则定义为public,因此任何人都可以窃取、修改或删除数据库中的数据

我尝试了几件事,但没有访问数据。。。只有当规则设置为true时,才能访问数据

但有没有办法修改规则,使其更安全

我希望只有少数已知的应用程序(我的应用程序)可以访问此数据

共有1个答案

葛宏爽
2023-03-14

从文档这里开始,用你的方式完成。它非常实用,易于理解。

只有当规则设置为true时,才能访问数据

Firebase RTDB有一个公共URL,所以任何人都可以尝试连接到它。你的工作是决定他们是否能做到这一点。如果任何路径/节点的规则如下所示,则任何提出请求的人都可以使用该规则:

{
  ".read": true,
  ".write": true
}

如果您只想让您的应用的用户连接到RTDB,您可以使用Firebase Auth并使用以下条件:

{
  ".read": "auth != null"
  ".write": "auth != null"
}

我希望只有少数已知的应用程序(我的应用程序)可以访问此数据

访问是在用户级别上决定的,而不是通过应用程序。从文档中的此处开始。

但有没有办法修改规则,使其更安全

在Firebase控制台中,或通过CLI部署它们。如果你是新手,从Firebase控制台开始,使用规则操场测试不同的规则。有关更多信息,请参阅文档。

所以除非有人可以访问我的谷歌账户或与我的数据库集成 /web应用程序...即使规则设置为真,也没有人可以访问数据,我说得对吗?

你的数据库不是“集成的”。它是一个部署的实例,可以通过公共网址访问——这就是你的客户端连接到RTDB的方式。如果你的规则允许任何读或写操作,那么你的数据库对每个人都是开放的。因此,你收到的通知你这不安全的电子邮件。

 类似资料:
  • 我创建了一个应用程序,它使用Firebase实时数据库。我对安全规则有一个很大的问题。我的用户不需要登录使用应用程序,他们可以发送数据到数据库,无需任何身份验证。例如:这是一个简单的游戏,他们可以互相玩,然后他们可以保存分数。我想创建一个安全的数据库,但是任何人都可以写

  • 我在中收到一条消息,告诉我我的项目有不安全的规则。但当我检查它时,我不太明白什么是不安全的。 它显示如下: 我保留了读取访问权限,因为它支持一个网站。所以任何访问该网站的人都应该能够读取数据。 至于写权限,据我所知,我是唯一能写的人。 请注意,我还有第三个系列(CollectionThree),规则中没有提到。这可能是原因吗? 除此之外,我还可以想象,只有web服务器可以获得读取权限,以便将内容提

  • 我在Android Studio中创建了一个应用程序,并将其与Firebase实时数据库链接。我需要执行3次验证: > 由Firebase通知服务生成的一次性PIN和手机验证。 在下一个屏幕上,用户的pin会根据我的数据库进行检查,最后他会进入菜单屏幕。 现在,我不知道应该设置什么作为我的安全规则,因为身份验证是在第2步进行的,所以我不能使用“auth”来设置规则,如果没有“auth”,数据库将是

  • 我需要一些帮助来保护我的数据库。 我的数据库如下所示(我使用的是电话号码,而不是uid): 如您所见,在用户节点下有经过身份验证的用户的电话号码。我的目标是保护数据库,这样用户就可以读写自己的数据。 我尝试了以下代码,以允许每个用户读取和写入自己的数据: 但每当我在规则游乐场或我的应用程序上尝试这一点时,我都会被拒绝: 你们能帮我解决吗?

  • 我需要一些帮助来保护我的数据库。 以下是我的安全规则: 我尝试了以下代码,以允许每个用户读取和写入自己的数据: 我的数据库如下所示(我使用的是电话号码,而不是uid): 但是由于某种原因,当我运行Firebase规则游乐场时,给定的auth.token.phone数等于我给出的确切位置,例如,我被拒绝读取选项。 这也发生在我的应用程序中,你们能帮我解决吗?

  • 我正在做一个我想在firebase实时数据库上运行的项目。我用以下格式创建了一个数据库设置: 我的安全规则如下所示: 我试图存档,每个人都可以阅读“马”、“图像”和“视频”中的详细信息,但只有经过身份验证的用户才能在“马”、“图像”和“视频”中添加自己的条目(由firebase auth提供的用户ID检查)。 我的第一个问题是:我应该把“图像”和“视频”作为“马”的子对象吗?如果我能为马写一条读写