为什么即使对象错误,validate函数也总是返回true?
const Ajv = require('ajv')
const ajv = new Ajv()
const schema = {
query: {
type: 'object',
required: ['locale'],
properties: {
locale: {
type: 'string',
minLength: 1,
},
},
},
}
const test = {
a: 1,
}
const validate = ajv.compile(schema)
const valid = validate(test)
console.log(valid) // TRUE
我的代码有什么问题?这是一个基本的例子。
最佳答案
空模式要么是{}
,要么是其键都不属于JSON模式词汇表的对象。无论哪种方式,空模式总是返回true:
const ajv = new Ajv();
const validate1 = ajv.compile({});
const validate2 = ajv.compile({
"a": "aaa",
"b": [1, 2, 3],
"c": {
"d": {
"e": true
}
}
});
validate1(42); // true
validate1([42]); // true
validate1('42'); // true
validate1({answer: 42}); // true
validate2(42); // true
validate2([42]); // true
validate2('42'); // true
validate2({answer: 42}); // true
您的情况
schema
不包含有效的架构。但是schema.query
会。将其传递给Ajv的compile
方法,它将按预期工作。const ajv = new Ajv()
const schema = {
query: {
type: 'object',
required: ['locale'],
properties: {
locale: {
type: 'string',
minLength: 1,
},
},
},
}
const test = {
a: 1,
}
const validate = ajv.compile(schema.query)
const valid = validate(test)
console.log(valid)
<script src="https://cdnjs.cloudflare.com/ajax/libs/ajv/6.10.2/ajv.min.js"></script>
另外,您可以在架构中添加
$id
并使用Ajv的getSchema
方法获取验证功能。这也适用:
const schema = {
query: {
$id: 'query-schema',
type: 'object',
required: ['locale'],
properties: {
locale: {
type: 'string',
minLength: 1,
},
},
},
}
const test = {
a: 1,
}
ajv.addSchema(schema)
const validate = ajv.getSchema('query-schema')
const valid = validate(test)
console.log(valid)