首页 文章

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

提问于
浏览
1

我正在使用Golang中的API,使用Gorm作为ORM . 目前我遇到了[]字节字段的问题,我在我的结构中将其定义为:

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

The code

To save:

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

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

To Read: db.First(&user,id)fmt.Println(user.MyField)

1 回答

  • 1

    我想你的问题是db.First(&user,id)的错误id . 可能你的生错了 . 我've tried to repoduce error and I couldn' t . 以下代码工作正常 .

    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")
    }
    

相关问题