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<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。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。