我有一个GORM应用程序,每次更新用户密码字段时,我都会尝试散列用户的密码字段。
为此,我使用了GORM提供的BeforeUpdate钩子。我面临的问题是,在上述钩子上,用户的Password字段(u.password)上已经存储在DB上的旧哈希密码值,而不是我正在更新的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
}发布于 2022-08-31 04:32:17
您可以从tx.Statement.Dest映射中获得新的密码值。这是SetColumn更新值到的相同的映射。
或在实际更新调用之前设置新密码值。
user.Password = newPassword
err = db.Model(&user).Updates(&user).Error在这种情况下,旧密码将无法在钩子上使用。
https://stackoverflow.com/questions/73550140
复制相似问题