var Game = sequelize.define('Game', {
secretField: {
type: DataTypes.STRING(45),
validate: {
notEmpty: true
}
}
}, {
getterMethods: {
secretFieldHash: function () {
return crypto.createHash('sha256').update(this.getDataValue('secretField')).digest('hex');
}
}
});
上面的模型是我当前模型的一个例子。我要实现的是以下目标。
我有一个“secretfield”,有时需要在后端代码中使用,但有时也只想在前端显示该字段的哈希版本。
这可能吗?
我的问题的另一个例子是玩家模型。您不想将密码发送到前端,但有时需要在后端使用它(例如,如果用户输入了正确的密码,则进行比较)。
最佳答案
您可能会期待以下内容(尚未实现):https://github.com/sequelize/sequelize/issues/1462
现在,您可以覆盖tojson方法,如下所示:
{
instanceMethods: {
toJSON: function () {
var resp = this.prototype.toJSON();
resp.secretField = hash(resp.secretField);
return resp;
}
}
}
通过这种方式,secret字段将对您的后端可用,但在将对象转换为json并发送给最终用户时将被删除。