Golang串行化并反串行化回

w6mmgewl  于 2022-12-25  发布在  Go
关注(0)|答案(2)|浏览(170)

在Golang中,将结构体序列化和反序列化为字符串的最佳方法是什么(完整性和性能)?
例如,如果我有这样的结构:

struct Session {
   Properties map[string]interface{}
   Permissions []int64
}

我想把它存到Redis上取回来。我试过保存,int和string,都可以,但是如何存储结构体对象呢?

conn := redisConnectors.Get()

// set example

_, err := conn.Do(`SETEX`, `uid_key`, EXPIRE_SEC, user_id)
_, err = conn.Do(`SETEX`, `email_key`, EXPIRE_SEC, login_email)

// get example

user_id, err := redis.Int64(conn.Do(`GET`, `uid_key`))
login_email, err := redis.String(conn.Do(`GET`, `email_key`))
flmtquvp

flmtquvp1#

使用gobbase64可以解决此问题,例如:

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
}

当你需要序列化自定义的struct或type(例如Session struct)时,只需添加下面几行:

func init() {
    gob.Register(SX{})
    gob.Register(Session{}) 
}

如果您希望将other serialization format(2020)或此benchmark(2022)用于动态结构

iyr7buue

iyr7buue2#

结构的序列化通常使用encoding包。但是,这只适用于公共字段。如果您还需要序列化私有字段,可以使用see this answer作为替代。
有几种编码选择(二进制、文本、json as in this example for a struct、xml等),例如cupcake/rdb项目使用encoding/binary实现RedisRDB file format(内存存储的二进制表示)的解析和编码,另一个例子是guregu/rediscache,Redis中用于缓存数据的小型库。

相关问题