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

实时数据库Firebase安全规则问题

刘阳荣
2023-03-14

我在Android Studio中创建了一个应用程序,并将其与Firebase实时数据库链接。我需要执行3次验证:

>

由Firebase通知服务生成的一次性PIN和手机验证。

在下一个屏幕上,用户的pin会根据我的数据库进行检查,最后他会进入菜单屏幕。

现在,我不知道应该设置什么作为我的安全规则,因为身份验证是在第2步进行的,所以我不能使用“auth”来设置规则,如果没有“auth”,数据库将是公共的(据我所知,如果我错了,请纠正我),这是不安全的。我们能做些什么?

共有1个答案

张卓
2023-03-14

实际上,正如您所提到的,在步骤1中没有身份验证。因此,如果您想“直接”读取实时数据库以检查电话号码是否存在,则无法避免每个人都可以访问实时数据库节点,该节点列出了所有电话号码。

另一种选择是使用云函数,该函数将通过HTTPS(作为RESTAPI)调用,并检查给定的电话号码是否在授权电话号码列表中。

通过这种方式,您可以对电话号码列表应用一些限制性的读取访问规则,因为云功能将以管理员的身份访问它。你只允许检查一个电话号码是否被授权,而不是公开所有电话号码的列表。

查看留档以阅读如何创建可以通过HTTP请求触发的函数https://firebase.google.com/docs/functions/http-events

基本上你会这样做:

exports.checkPhoneNbr = functions.https.onRequest((req, res) => {
  let phoneNumberToCheck = req.query.phoneNumber;

  return admin.database().ref('/phoneNumbers/' + phoneNumberToCheck).once('value').then(snapshot => {
    if (snapshot.val()) {
       //the phone number exists, do something, i.e. write to another database node or send back a successful HTTP response
      //i.e. res.status(200).send("PhoneNbrExists");
    } else {
       //i.e. res.status(200).send("PhoneNbrDoesNotExist");
    }
   }
}

所以:

1/从Android应用程序(通过HTTPS)调用此函数,在函数URL的查询字符串中输入电话号码

2/云函数检查电话号码是否存在。如果存在,它可以发回一条成功消息(或写入实时数据库的其他节点)。如果没有,它会发回一条失败消息。

3/在Android应用程序中,在收到云功能的响应后,继续(或不继续)下一步

另外,请查看函数示例,尤其是HTTPhtml" target="_blank">示例,如:

https://github.com/firebase/functions-samples/blob/master/quickstarts/time-server/functions/index.js

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

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

  • 好的,我有一个实时数据库连接到一个应用程序,直到今天规则(读写)都设置为真,一切都很好。。。。但每次有消息说 您的安全规则定义为public,因此任何人都可以窃取、修改或删除数据库中的数据 我尝试了几件事,但没有访问数据。。。只有当规则设置为true时,才能访问数据 但有没有办法修改规则,使其更安全 我希望只有少数已知的应用程序(我的应用程序)可以访问此数据

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

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

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