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。