我想使用 Cerberus 来验证对象中不存在字段。
我想使用类似的东西:
my_schema = {
'normal_field': {
'type': 'string',
},
'forbidden_field': {
'forbid': True,
},
}
基本上,我永远不想接受forbidden_field
附带的对象。现在我接受更改我的验证器:
validator.allow_unknown = False
这基本上可以设置仅包含"允许"字段的模式,但我真的不喜欢它的作用,因为这禁止我接受其他字段,而不仅仅是forbidden_field
。
我还看到了allowed
和forbidden
验证规则,但它们检查字段的值,而不是字段的存在。
那么,我怎么能告诉我的验证者只禁止地狱犬的特定字段存在呢?
我似乎记得以前遇到过这个特殊的用例。您可以尝试以下操作:
from cerberus import Validator
schema = {
'foo': {
'type': 'string',
'validator': lambda field, value, error: error(field, 'field is forbidden!!'),
}
}
v = Validator(schema)
v.allow_unknown = True
doc = {
'foo': 'bar'
}
print(v.validate(doc))
结果应该返回False
,v.errors
应该说"禁止字段!!
看:
-
validator
在 Cerberus 文档中的验证规则下
我用readonly
规则解决了这个问题,这也允许我设置一个default_setter
值。
@kchan的答案适用于不允许该字段,但它破坏了规范化集成(例如,尝试将其与default_setter
一起使用(。