温馨提示:本文翻译自stackoverflow.com,查看原文请点击:javascript - Joi custom validation
javascript node.js validation customvalidator joi

javascript - Joi自定义验证

发布于 2020-03-27 11:36:00

我正在使用Joi验证来自用户的某些数据。我将其与这样的模块一起使用:

const Joi = require('joi')

// User validation rules
module.exports = {
  create: {
    body: {
      email: Joi.string().email().required(),
      password: Joi.string().min(6).max(128).required(),
      name: Joi.string().max(128).required()
    }
  },
  update: {
    body: {
      password: Joi.string().min(6).max(128).required(),
      name: Joi.string().max(128).required()
    }
  }
}

然后在路由器中将其作为中间件传递:

router.post('/register', validator(create), userController.register)

对于更新,我想使用以下代码创建自定义验证器:

const json = { 
  "email":"aa@aa.pl",
  "password":"someNewPass",
  "name":"John Smith",
  "activationKey":"123123",
  "active":false,
  "resetPasswordKey":"123123"
}

const forbiddenFields = ["email", "activationKey", "active", "resetPasswordKey"];

const validate = (json, forbidden) => {
  for(let i = 0; i < forbidden.length; i++) {
    if(json.hasOwnProperty(forbidden[i])) {
      return false;
    }
  }
  return true;
}

const isValid = validate(json, forbiddenFields)
console.log('is json valid? ', isValid)

在Joi API中发现了extend方法,但是示例如此混乱,以至于我无法使用我的代码创建自定义验证。

查看更多

查看更多

提问者
dopeCode
被浏览
104
antonku 2019-07-03 23:11

您可能要使用禁止的钥匙。

const input = {
    email: 'example@example.com',
    activationKey: 123
};

const schema = {
    email: Joi.string().email(),
    activationKey: Joi.any().forbidden()
};

const result = Joi.validate(input, schema);

if (result.error) {
    console.log(result.error.details)
}
<script src="https://cdn.jsdelivr.net/npm/joi-browser@13.4.0/dist/joi-browser.min.js"></script>