Javascript 为什么验证规则在onDisconnect update中的行为不同(仅限于)?
我用firebase做了一些测试,发现规则中使用Javascript 为什么验证规则在onDisconnect update中的行为不同(仅限于)?,javascript,firebase,firebase-realtime-database,firebase-security,Javascript,Firebase,Firebase Realtime Database,Firebase Security,我用firebase做了一些测试,发现规则中使用newData.parent()的onDisconnect().update()和simpleupdate()在规则验证方面存在差异 当我使用update()时,它可以工作。但是使用onDisonnect().update()我的权限被拒绝了 数据库规则: { "rules": { "$id": { ".read": true, ".write": true,
newData.parent()
的onDisconnect().update()
和simpleupdate()
在规则验证方面存在差异
当我使用update()
时,它可以工作。但是使用onDisonnect().update()
我的权限被拒绝了
数据库规则:
{
"rules": {
"$id": {
".read": true,
".write": true,
"a": { ".validate": true },
"b": { ".validate": "newData.parent().child('a').val() == 'a'" },
}
}
}
Javascript:
const valid = {
a: 'a',
b: 'b'
};
function update(obj) {
console.log('update', obj);
return ref.update(obj);
}
function onDisconnectUpdate(obj) {
console.log('onDisconnectUpdate', obj);
return ref.onDisconnect().update(obj);
}
update(valid);
onDisconnectUpdate(valid);
我希望你能帮助我。这里是firebaser
在执行
onDisconnect()
操作期间,在验证规则时,每个属性都被视为一个单独的写入操作。这意味着在您的情况下,操作失败。虽然这是一个不幸的设计,但在不久的将来不太可能改变。出于这个原因,我建议在onDisconnect()
处理程序中使用更简单的写操作。好问题道格拉斯。我花了一些时间才找到我在下面贴出的(不幸的)答案。