亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Go GORM - BeforeUpdate 字段有舊值

Go GORM - BeforeUpdate 字段有舊值

Go
慕桂英3389331 2023-02-06 14:42:46
我有一個帶有 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

在這種情況下,舊密碼將無法使用。


查看完整回答
反對 回復 2023-02-06
  • 1 回答
  • 0 關注
  • 225 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號