比特币作为区块链的一个应用,它建立在分布式系统之上,‘节点’遍布全球。为了使所有节点协同工作并作为一个整体系统运行,需要保持所有节点同步在相同的状态中,也就是说节点之间需要频繁通信,并且相互交换大量数据消息。这要求在网络上传输的消息或数据要使用某种格式编码,以确保数据内容的安全,并且编码方案应确保编码后的数据包尽可能小,以提高众多节点之间通信的效率。
当比特币用户创建钱包时,他/她需要发布其钱包的地址,这样他/她可以接收或向他人发送资金。钱包地址实际上是我们在上一节创建的公钥,并编码为一种叫做SEC(高效密码学标准)的格式。SEC格式有两种形式,分别是未压缩和压缩格式。首先让我们来看未压缩格式。对于公钥 P=(x,y)P=(x,y),x 和 y 的坐标是32字节整数,使用以下步骤将密钥编码为未压缩的SEC格式:
起始字节设为0x04,
将x值转为大端字节序并附加在0x04之后
将y值转为大端字节序并附加在x的末尾
以下是SEC未压缩格式的一个示例:
047211a824f55b505228e4c3d5194c1fcfaa15a456abdf37f9b9d97a4040afc073dee
标签:编码,公钥,字节,压缩,golang,SEC,格式,节点 From: https://blog.csdn.net/tyler_download/article/details/143709344