gpt4 book ai didi

mysql - 使用BeforeUpdate的gorm哈希密码不会使用哈希值更新密码

转载 作者:行者123 更新时间:2023-12-01 22:33:31 24 4
gpt4 key购买 nike

我有一个非常简单的User模型,下面是我的整个main.go

package main

import (
"fmt"

"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql"
"golang.org/x/crypto/bcrypt"
)

// User : the user data model
type User struct {
gorm.Model

Username string `gorm:"type:varchar(40);unique" json:"username,omitempty"`
Password string `gorm:"size:255" json:"password,omitempty"`
}

// BeforeSave : hook before a user is saved
func (u *User) BeforeSave(scope *gorm.Scope) (err error) {
fmt.Println("before save")
fmt.Println(u.Password)
if u.Password != "" {
hash, err := MakePassword(u.Password)
if err != nil {
return nil
}
u.Password = hash
}

fmt.Println(u.Password)
return
}

// MakePassword : Encrypt user password
func MakePassword(password string) (string, error) {
bytes, err := bcrypt.GenerateFromPassword([]byte(password), bcrypt.DefaultCost)
return string(bytes), err
}

func main() {
var connectionString = fmt.Sprintf(
"%s:%s@/%s?charset=utf8&parseTime=True&loc=Local",
"root", "password", "project",
)

db, _ := gorm.Open("mysql", connectionString)
db.AutoMigrate(&User{})
db.Save(&User{
Username: "name1",
Password: "123",
})

db.Model(&User{
Model: gorm.Model{ID: 1},
}).Update(&User{
Username: "name2",
Password: "12345",
})
}
第一次创建密码时,便会创建密码并将其另存为哈希字符串(我注释掉了第二个更新部分并对其进行了测试),但是在更新时,密码另存为纯文本。
从控制台中,我可以看到 Println消息,触发了 BeforeUpdate,并且看到了它的纯口令和MD5,但是在数据库中,它被另存为纯文本。
before save
123
$2a$10$Vknv/uu7tAPRQSddPVlQ7OodIHZJmRPKktjb98U8U5.GT/OLQeQE2
before save
12345
$2a$10$K0ZkLH7slfiFmkOe5DTKr.DGNvR6HtpjxCS/1svf2ZEvfTXVkMkvu
关于如何解决该问题的任何想法?

最佳答案

According to the docs为了更改要更新的值,必须通过gorm Scope参数设置它们。在这种情况下,User结构不用于修改。您应该改用SetColumn。

// BeforeUpdate : hook before a user is updated
func (u *User) BeforeUpdate(scope *gorm.Scope) (err error) {
fmt.Println("before update")
fmt.Println(u.Password)

if u.Password != "" {
hash, err := MakePassword(u.Password)
if err != nil {
return nil
}
scope.SetColumn("Password", hash)
}

fmt.Println(u.Password)
return
}

关于mysql - 使用BeforeUpdate的gorm哈希密码不会使用哈希值更新密码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63484061/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com