我将钩子beforeCreate定义如下:
module.exports = function (sequelize, DataTypes) {
var userSchema = sequelize.define('User', {
// define...
});
userSchema.beforeCreate(function (model) {
debug('Info: ' + 'Storing the password');
model.generateHash(model.password, function (err, encrypted) {
debug('Info: ' + 'getting ' + encrypted);
model.password = encrypted;
debug('Info: ' + 'password now is: ' + model.password);
// done;
});
});
};
当我创建模型时
User.create({
name: req.body.name.trim(),
email: req.body.email.toLowerCase(),
password: req.body.password,
verifyToken: verifyToken,
verified: verified
}).then(function (user) {
debug('Info: ' + 'after, the password is ' + user.password);
}).catch(function (err) {
// catch something
});
现在我从中得到的是
Info: Storing the password +6ms
Info: hashing password 123123 +0ms // debug info calling generateHash()
Executing (default): INSERT INTO "Users" ("id","email","password","name","verified","verifyToken","updatedAt","createdAt") VALUES (DEFAULT,'wwx@test.com','123123','wwx',true,NULL,'2015-07-15 09:55:59.537 +00:00','2015-07-15 09:55:59.537 +00:00') RETURNING *;
Info: getting $2a$10$6jJMvvevCvRDp5E7wK9MNuSRKjFpieGnO2WrETMFBKXm9p4Tz6VC. +0ms
Info: password now is: $2a$10$6jJMvvevCvRDp5E7wK9MNuSRKjFpieGnO2WrETMFBKXm9p4Tz6VC. +0ms
Info: after, the password is 123123 +3ms
似乎代码的每个部分都在工作。创建用户模式将调用beforeCreate,它将正确生成密码的哈希码....,但它没有写入数据库!
我确定我错过了非常重要且显而易见的代码,但我只是找不到问题所在(啊)。任何帮助表示赞赏!
在Sequelize中,钩子是通过异步方式调用的,因此完成后需要调用完成回调:
userSchema.beforeCreate(function(model, options, cb) {
debug('Info: ' + 'Storing the password');
model.generateHash(model.password, function(err, encrypted) {
if (err) return cb(err);
debug('Info: ' + 'getting ' + encrypted);
model.password = encrypted;
debug('Info: ' + 'password now is: ' + model.password);
return cb(null, options);
});
});
(或者,您可以从挂钩中返回一个承诺)
问题内容: 使用内联formset docs中的示例,我能够(使用modelforms)编辑属于特定模型的对象。我一直在尝试使用相同的模式来 使用内联表单集创建新对象,但是一直无法清除我的头来为此目的提供工作视图。 使用与上述链接相同的示例,我将如何创建“作者”模型的新实例及其相关的“书”对象? 问题答案: 首先,创建一个Author模型表单。 然后创建一个虚拟作者对象: 然后使用伪作者创建内联表
问题内容: 如何建立持续集成标签而不是分支的实践? 我具有标签存储库目录的以下结构: 我想配置我的持续集成工具(可以是CruiseControl,Hudson和Jenkins到TeamCity的任何工具),以在两个文件夹中的任何一个中创建了最新标记。 例如,如果结构已更改并且标签已出现在目录中,我想触发标签下的源代码构建: 是否可以使用任何现有的持续集成工具在标签下构建源代码,或者为此目的我应该编
所有的生命周期钩子自动绑定this上下文到实例中,因此你可以访问数据,对属性和方法进行运算。这意味着你不能使用箭头函数来定义一个生命周期方法(例如created: () => this.fetchTodos())。这是因为箭头函数绑定了父上下文,因此this与你期待的 Vue 实例不同,this.fetchTodos的行为未定义。 beforeCreate 类型:Function 详细: 在实例初
太长,读不下去了如何模拟或使用带有数组的道具强制重置我的组件? 我正在实现一个组件,它显示一个计时器,并在达到零时执行回调。目的是让回调更新对象列表。后一个组件由新的React钩子和组成。 包含对计时器启动时间和剩余时间的引用。设置每秒钟调用一次的间隔,以更新剩余的时间,并检查是否应该调用回调。 该组件并不意味着重新安排计时器,或者在间隔达到零时保持间隔,它应该执行回调并空闲。为了让计时器刷新,我
现在我们来试一试从代码托管平台上拉取代码,并进行镜像构建和持续集成。 创建新项目并构建镜像 在控制台点击「代码构建」,然后在「代码构建」的界面中点击「创建新项目」。 第一步:填写项目名称 在「项目名称」上填写该项目的 Docker 镜像名称。 第二步:选择代码库 从第三方代码托管平台中选择我们想要构建的代码库,如果找不到需要的代码库可以点击右上角刷新按钮同步列表。 第三步:开启持续集成 持续集成是