时事通讯签约表单的实时数据库规则
本文介绍了时事通讯签约表单的实时数据库规则的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我的网站上只有一个字段表单,可以用来注册时事通讯。它询问电子邮件地址并将其提交到Firebase数据库。我不希望除我以外的任何人阅读它,我也不希望任何人能够更新或删除其中的任何内容。
我希望允许公众做的所有事情就是向数据库写入电子邮件地址。
这是我当前的规则:
{
"rules": {
"emails": {
"$uid": {
".write": "!data.exists()",
"mail" : {
".validate": "newData.val().matches(/^.*[@].*[.].*$/)"
}
}
}
}
}
它接受如下内容:
firebase.database().ref('emails').push().set({mail: "test@gmail.com"});
并否认以下内容:
firebase.database().ref('emails').push().set({mail: "test"});
但仍接受这一点:
firebase.database().ref('emails').push().set({test: "test"});
我如何修复此问题?
推荐答案
您将希望use a $
wildcard rule拒绝任何其他内容:
"$uid": {
".write": "!data.exists()",
"mail" : {
".validate": "newData.val().matches(/^.*[@].*[.].*$/)"
},
"$other": {
".validate": false
}
}
这篇关于时事通讯签约表单的实时数据库规则的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,