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

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

做网站、成都网站设计,成都做网站公司-创新互联已向数千家企业提供了,网站设计,网站制作,网络营销等服务!设计与技术结合,多年网站推广经验,合理的价格为您打造企业品质网站。

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

    EncodeBase58Check = Base58Encode(plain + hash(plain))

2、class CBase58Data有两个成员vector_uchar vchData;和std::vector 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。


分享名称:BitCoin源码研究(2)-由Base58编码扩展来的几个类型
文章源于:http://myzitong.com/article/jdsoci.html