首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Go GORM - BeforeUpdate字段有旧的值

Go GORM - BeforeUpdate字段有旧的值
EN

Stack Overflow用户
提问于 2022-08-31 01:56:17
回答 1查看 106关注 0票数 0

我有一个GORM应用程序,每次更新用户密码字段时,我都会尝试散列用户的密码字段。

为此,我使用了GORM提供的BeforeUpdate钩子。我面临的问题是,在上述钩子上,用户的Password字段(u.password)上已经存储在DB上的旧哈希密码值,而不是我正在更新的newPassword值。因此,当我在钩子上散列密码时,我实际上只是对已经散列的旧密码进行了散列。

我的BeforeUpdate钩子:

代码语言:javascript
复制
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
}

更新是这样触发的:

代码语言:javascript
复制
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钩子:

代码语言:javascript
复制
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
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-08-31 04:32:17

您可以从tx.Statement.Dest映射中获得新的密码值。这是SetColumn更新值到的相同的映射。

或在实际更新调用之前设置新密码值。

代码语言:javascript
复制
user.Password = newPassword
err = db.Model(&user).Updates(&user).Error

在这种情况下,旧密码将无法在钩子上使用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73550140

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档