检查唯一的用户名

检查唯一的用户名

本文介绍了sequelize.js 自定义验证器,检查唯一的用户名/密码的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

假设我已经定义了以下自定义验证器函数:

Imagine I have defined the following custom validator function:

isUnique: function () { // This works as expected
  throw new Error({error:[{message:'Email address already in use!'}]});
}

但是,当我尝试查询数据库时,我遇到了问题:

However, when I attempt to query the DB I run into problems:

isUnique: function (email) { // This doesn't work
  var User = seqeulize.import('/path/to/user/model');

  User.find({where:{email: email}})
    .success(function () { // This gets called
      throw new Error({error:[{message:'Email address already in use!'}]});  // But this isn't triggering a validation error.
    });
}

如何在自定义验证器中查询 ORM 并根据 ORM 的响应触发验证错误?

How can I query the ORM in a custom validator and trigger a validation error based on the response from the ORM?

推荐答案

你可以这样验证邮箱是否已经存在:

You can verify if the email already exists like that:

email: {
  type: Sequelize.STRING,
  allowNull: false,
  validate: {
    isEmail:true
  },
  unique: {
      args: true,
      msg: 'Email address already in use!'
  }
}

这篇关于sequelize.js 自定义验证器,检查唯一的用户名/密码的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

07-22 10:03