gpt4 book ai didi

go - 从数据库中保存和读取 Golang 中的 byte[]

转载 作者:IT王子 更新时间:2023-10-29 02:11:46 28 4
gpt4 key购买 nike

我正在使用 Golang 开发 API,使用 Gorm 作为 ORM。当前 []byte 字段有问题,我在我的结构中将其定义为:

type Member struct {
MyField []byte `gorm:"column:MyField" schema:"-"`
}

然后,我有保存和读取该资源的方法,所以我保存它时的值与我正在读取的值不同。例如,我使用 bcrypt 生成散列密码,尝试使用 12345 结果是:

[36 50 97 36 49 48 36 46 56 98 88 72 82 71 113 66 100 65 105 103 70 119 114 97 73 77 99 78 117 106 54 78 103 88 68 49 56 110 103 112 105 86
104 79 117 47 114 57 116 51 47 53 97 100 109 103 106 46 68 109]

直到一切正常,然后当我从数据库中读取寄存器并打印该值时,我得到:

[36 50 97 36 48 52 36 56 49 67 66 121 118 90 47 47 104 49 83 120 50 108 112 71 73 51 67 88 46 97 52 74 54 66 84 73 106 105 110 122 98 69 90 51
78 113 67 66 49 103 50 56 116 47 57 120 78 103 109 54]

它们是不同的,为什么?我使用 gorm 创建表,该列的类型在我的 postgres 数据库中定义为 bytea

代码

保存:

bs, err := bcrypt.GenerateFromPassword([]byte(Pass), bcrypt.DefaultCost)    

if err != nil {
fmt.Println("Hey error!")
}
user.MyField = bs
db.Create(&user)

阅读: db.First(&用户,id)fmt.Println(用户.MyField)

最佳答案

我想您的问题是 db.First(&user,id) 中的错误 ID。您可能弄错了行。我试图重现您的错误,但没有成功。以下代码工作正常:

bs, err := bcrypt.GenerateFromPassword([]byte("12345"), bcrypt.DefaultCost)
expected := bs

db.Create(&Member{MyField: bs})
var member Member

db.First(&member)
actual := member.MyField

if !bytes.Equal(actual, expected) {
panic("fields are not equal")
}

关于go - 从数据库中保存和读取 Golang 中的 byte[],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44547272/

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