BitCoin源码研究(2)-由Base58编码扩展来的几个类型
1、EncodeBase58Check的结果与DecodeBase58Check的输入:
base58编码前会add 4-byte hash check to the end,解码则会在解码后用4-byte hash对结果进行校验。
EncodeBase58Check =Base58Encode(plain + hash(plain))
2、classCBase58Data有两个成员vector_uchar vchData;和std::vector<unsigned char> vchVersion;
ToString函数会将vchData放在vchVersion之后,然后做EncodeBase58Check
ToString=Base58Encode(version + plain + hash(version + plain))
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。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。