我在Golang中有以下类型:
type Base64Data []byte
为了支持将base64编码的字符串解组为此类型,我执行了以下操作:
func (b *Base64Data) UnmarshalJSON(data []byte) error {
if len(data) == 0 {
return nil
}
content, err := base64.StdEncoding.DecodeString(string(data[1 : len(data)-1]))
if err != nil {
return err
}
*b = []byte(xml)
return nil
}
现在我也希望能够使用mgo Golang库将其编组并解组到mongo数据库 . 问题是我已经将文件存储为base64编码的字符串,所以我必须保持这一点 . 我试着做以下事情:
func (b Base64Data) GetBSON() (interface{}, error) {
return base64.StdEncoding.EncodeToString([]byte(b)), nil
}
func (b *Base64DecodedXml) SetBSON(raw bson.Raw) error {
var s string
var err error
if err = raw.Unmarshal(&s); err != nil {
return err
}
*b, err = base64.StdEncoding.DecodeString(s)
return err
}
因此,在解组之后,数据已经被解码,所以我需要对其进行编码,并将其作为字符串返回,以便将其作为字符串写入db(反之亦然)为此我实现了bson getter和setter,但是似乎只有吸气剂正常工作
来自base64编码字符串的JSON解组工作,以及将其编组到数据库 . 但似乎根本没有打电话 .
任何人都可以建议我缺少什么,以便我能够正确地保存在内存中解码的数据,但编码的字符串类型?
这是我试图运行的测试:
b := struct {
Value shared.Base64Data `json:"value" bson:"value"`
}{}
s := `{"value": "PHJvb3Q+aGVsbG88L3Jvb3Q+"}`
require.NoError(t, json.Unmarshal([]byte(s), &b))
t.Logf("%v", string(b.Value))
b4, err := bson.Marshal(b)
require.NoError(t, err)
t.Logf("%v", string(b4))
require.NoError(t, bson.Unmarshal(b4, &b))
t.Logf("%v", string(b.Value))