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<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。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章