BitCoin源码研究-由Base58编码扩展来的几个类型

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BitCoin源码研究-由Base58编码扩展来的几个类型相关的知识,希望对你有一定的参考价值。

1、EncodeBase58Check的结果与DecodeBase58Check的输入:

    base58编码前会add 4-byte hash check to the end,解码则会在解码后用4-byte hash对结果进行校验。


2、class CBase58Data有两个成员vector_uchar vchData;和std::vector<unsigned char> vchVersion;

    ToString函数会将vchData放在vchVersion之后,然后做EncodeBase58Check


3、class CBitcoinAddress : public CBase58Data分两种类型:CChainParams::PUBKEY_ADDRESS和CChainParams::SCRIPT_ADDRESS类型

    CChainParams::PUBKEY_ADDRESS和CChainParams::SCRIPT_ADDRESS会在vchVersion中存储

    CKeyID和CScriptID则会在vchData中存储,两种类型的vchData都为20字节


4、class CBitcoinSecret : public CBase58Data 类型为CChainParams::SECRET_KEY,如果私钥为压缩的则会在vchData之后push_back(1)。私钥不压缩时为32个字节,压缩后第33个字节为1。

本文出自 “清澈” 博客,转载请与作者联系!

以上是关于BitCoin源码研究-由Base58编码扩展来的几个类型的主要内容,如果未能解决你的问题,请参考以下文章

base58编码python实现 -bitcoin

Bech32编码 产生背景

Base64算法

Go语言实现Base64Base58编码与解码

高级密钥和地址

go语言 base58编码解码