在Sequelize中使用实例方法

sur*_*rth 19 javascript postgresql node.js sequelize.js

有人可以帮我理解如何在Sequelize中使用实例方法吗?我已经查看了文档,但发现它很稀疏.目前,我正在尝试在我的用户模型上使用setPassword和verifyPassword实例方法.当我尝试在REPL中调用代码时,在导入用户模型并同步数据库之后,我得到以下内容:

> models.User.setPassword('test');
TypeError: Object [object Object] has no method 'setPassword'
Run Code Online (Sandbox Code Playgroud)

以下是用户模型的代码:

var bcrypt = require('bcrypt');

module.exports = function(sequelize, DataTypes) {
  return sequelize.define('User', {
    email: { type: DataTypes.STRING, unique: true, allowNull: false, validate: { isEmail: true } },
    password: { type: DataTypes.STRING, allowNull: false},
    firstName: {type: DataTypes.STRING},
    lastName: {type: DataTypes.STRING},
    companyName: {type: DataTypes.STRING},
    admin: {type: DataTypes.BOOLEAN, allowNull: false, defaultValue: false,},
    forgotUrl: {type: DataTypes.STRING, unique: true},
    forgotDate: {type: DataTypes.STRING},
    lastLogin: {
      type: DataTypes.DATE,
      defaultValue: DataTypes.NOW
    }
  }, {
    paranoid: true,
    instanceMethods: {
      setPassword: function(password, done) {
        return bcrypt.genSalt(10, function(err, salt) {
          return bcrypt.hash(password, salt, function(error, encrypted) {
            this.password = encrypted;
            this.salt = salt;
            return done();
          });
        });
      },
      verifyPassword: function(password, done) {
        return bcrypt.compare(password, this.password, function(err, res) {
          return done(err, res);
        });
      }
    }
  });
};
Run Code Online (Sandbox Code Playgroud)

Ser*_*geS 16

实例方法可以用于特定元素实例,例如.

models.User.find(123).success( function( user ) { 
    user.setPassword('test');
});
Run Code Online (Sandbox Code Playgroud)

  • surfearth."done"是setPassword的第二个参数,它必须是一个函数,因为你称之为"return done();".您没有传入参数,因此"完成"未定义且不是函数. (2认同)