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并发送给最终用户时将被删除。

10-06 15:38