我有一个带有 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.Usererr := db.First(&user, id).Errorif (err != nil) { log.Fatal(err) }// Not sure how to access this "newPassword" value on the "BeforeUpdate" hookerr = db.Model(&user).Update("password", newPassword).Errorif (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}
1 回答
月关宝盒
TA贡献1772条经验 获得超5个赞
tx.Statement.Dest
您可以从映射中获取新密码值。这是将SetColumn
值更新为的同一张地图。
或者在实际更新调用之前设置新密码值。
user.Password = newPassword err = db.Model(&user).Updates(&user).Error
在这种情况下,旧密码将无法使用。
- 1 回答
- 0 关注
- 203 浏览
添加回答
举报
0/150
提交
取消