我正在尝试学习Golang并拥有Python背景知识.我目前正试图了解如何将变量打包成二进制格式(带校验和).在Python中我会使用类似的东西:
import struct
import hashlib
a = 100
b = "foo\x00\x00" # Padded to fixed length
packet = struct.pack('<B5s', a, b)
digest = hashlib.sha256(packet).digest()
packet += digest
Run Code Online (Sandbox Code Playgroud)
要在Go中执行相同的操作,我正在尝试这样的代码:
package main
import (
"crypto/sha256"
"fmt"
"encoding/binary"
"bytes"
)
type packet struct {
a uint8
b string
}
func main() {
var p = packet{}
p.a = 1
p.b = "foo\x00\x00"
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, &p)
h := sha256.New()
h.Write(buf.String())
fmt.Printf("% x\n", p)
}
Run Code Online (Sandbox Code Playgroud)
不幸的是,然而我攻击它似乎陷入了冲突变量类型(缓冲区,字节数组和字符串)的噩梦.我很欣赏一些指导,即我是否采取了正确的方法.
更新为有效的东西.
package main
import (
"bytes"
"crypto/sha256"
"encoding/binary"
"fmt"
)
type packet struct {
a uint8
b []byte
}
func main() {
var p = packet{}
p.a = 1
p.b = []byte("foo\x00\x00")
buf := bytes.Buffer{}
err := binary.Write(&buf, binary.BigEndian, p.a)
if err != nil {
fmt.Println(err)
}
_, err = buf.Write(p.b)
if err != nil {
fmt.Println(err)
}
h := sha256.New()
h.Write(buf.Bytes())
hash := h.Sum([]byte{})
fmt.Printf("% x\n", hash)
}
Run Code Online (Sandbox Code Playgroud)
http://play.golang.org/p/t8ltu_WCpe
你是对的,使用编码/二进制文件编写带有可能动态长度项的结构(切片和字符串)会有点痛苦.您可能有兴趣检查自动编码字符串的"encoding/gob"包(尽管它与您在此处获得的填充字符串不兼容).