我有一个带有 GORM 的 Go 应用程序,我试图在每次更新时散列用户的密码字段。
为此,我使用了BeforeUpdateGORM 提供的钩子。我面临的问题是,在上述挂钩上Password,用户 ( u.password) 的字段具有已存储在数据库中的旧哈希密码值,而不是newPassword我更新它的值。因此,当我对钩子上的密码进行哈希处理时,我实际上只是在对已经进行哈希处理的旧密码进行哈希处理。
我的BeforeUpdate钩子:
func (u *User) BeforeUpdate(tx *gorm.DB) (err error) {
if (tx.Statement.Changed("Password")) {
bytePassword := []byte(u.Password) // Old password value here!
passwordHash, err := bcrypt.GenerateFromPassword(bytePassword, bcrypt.DefaultCost)
if (err != nil) { return err }
tx.Statement.SetColumn("password", string(passwordHash))
}
return nil
}
更新是这样触发的:
var user models.User
err := db.First(&user, id).Error
if (err != nil) { log.Fatal(err) }
// Not sure how to access this "newPassword" value on the "BeforeUpdate" hook
err = db.Model(&user).Update("password", newPassword).Error
if (err != nil) { log.Fatal(err) }
编辑:工作解决方案感谢@s3vt 的回答
只需要改变我的BeforeUpdate钩子:
func (u *User) BeforeUpdate(tx *gorm.DB) (err error) {
if (tx.Statement.Changed("Password")) {
u.Password = tx.Statement.Dest.(map[string]interface{})["password"].(string)
bytePassword := []byte(u.Password)
passwordHash, err := bcrypt.GenerateFromPassword(bytePassword, bcrypt.DefaultCost)
if (err != nil) { return err }
tx.Statement.SetColumn("password", string(passwordHash))
}
return nil
}
月关宝盒
相关分类