解析msgpack编码的单个切片的msgpack编码的切片时为空片

时间:2019-03-29 12:05:32

标签: go gzip msgpack

我正在尝试解码来自服务器的gzip响应,该响应是最终gzip的msgpack数组或msgpack数组。

为了说明这一点,我的回答类似于:

gzip(msgpack([msgpack([]), msgpack([]), msgpack([]) ....]))

这是我到目前为止所做的,但是我收到msgpack错误

msgpack: invalid code=3f decoding array length,因此我得到的只是空片。

我从SO answer那里获得的这个getBytes函数

func getBytes(key interface{}) ([]byte, error) {
    var buf bytes.Buffer
    enc := gob.NewEncoder(&buf)
    err := enc.Encode(key)
    if err != nil {
        return nil, err
    }
    return buf.Bytes(), nil
}

var unZipped io.Reader
unZipped, err = gzip.NewReader(resp.Body)
var dataBytes bytes.Buffer
_, err = dataBytes.ReadFrom(unZipped)
if err != nil {
    logger.Println("error un gzipping", err)
}
var packedSlices []interface{}
bytesSlice := dataBytes.Bytes()
err = msgpack.Unmarshal(bytesSlice, &packedSlices)
for _, c := range packedSlices {
    var packedSlice []interface{}
    byts, _ := getBytes(c)
    err = msgpack.Unmarshal(byts, &packedSlice)
    logger.Println(err, packedSlice)
}

当我在python 3.7中执行相同的操作时,它工作正常:

resp = requests.post(url, headers=headers, json=payload, stream=True)
datas = msgpack.loads(gzip.decompress(resp.raw.data))
datas = [msgpack.loads(k) for k in datas]

我这里缺少什么吗?

1 个答案:

答案 0 :(得分:1)

使用[]interface{}代替将[][]byte类型用作解压缩类型。将根msg解组为[][]byte,然后遍历字节片的切片并解组每个子字节片。您不需要getBytes函数。

这里有个例子:

var root [][]byte
if err :=  msgpack.Unmarshal(bytesSlice, &root); err != nil {
    panic(err)
}

for _, childBytes := range root {
    var child []interface{}
    if err := msgpack.Unmarshal(childBytes, &child); err != nil {
        panic(err)
    }

    _ = child
}