2 回答
TA贡献1865条经验 获得超7个赞
使用gob和base64可以解决问题,例如:
import (
"encoding/base64"
"encoding/gob"
"bytes"
)
type SX map[string]interface{}
// go binary encoder
func ToGOB64(m SX) string {
b := bytes.Buffer{}
e := gob.NewEncoder(&b)
err := e.Encode(m)
if err != nil { fmt.Println(`failed gob Encode`, err) }
return base64.StdEncoding.EncodeToString(b.Bytes())
}
// go binary decoder
func FromGOB64(str string) SX {
m := SX{}
by, err := base64.StdEncoding.DecodeString(str)
if err != nil { fmt.Println(`failed base64 Decode`, err); }
b := bytes.Buffer{}
b.Write(by)
d := gob.NewDecoder(&b)
err = d.Decode(&m)
if err != nil { fmt.Println(`failed gob Decode`, err); }
return m
}
当您需要序列化自定义结构或类型(例如Session结构)时,只需添加以下几行:
func init() {
gob.Register(SX{})
gob.Register(Session{})
}
TA贡献1886条经验 获得超2个赞
结构的序列化通常使用encoding
包。但是,这仅适用于公共领域。如果您还需要序列化私有字段,请参阅此答案作为替代方案。
您有多种编码选择(二进制、文本、json,如本示例中的 struct、 xml 等)。例如,该项目cupcake/rdb
用于encoding/binary
实现Redis RDB 文件格式(内存存储的二进制表示)的解析和编码。另一个例子是guregu/rediscache
,一个用于在 Redis 中缓存数据的小型库。
- 2 回答
- 0 关注
- 248 浏览
添加回答
举报