我正在使用:https://github.com/bitcoin-abe/bitcoin-abe将区块链导入到mysql DB中,这几乎是在5天之后完成的。所以我开始查看数据并没有看到任何地址。我知道BTC客户端不使用它们,但将它们放在另一个表中仍然会很好。我环顾四周代码,发现了这个:
def hash_to_address(version, hash):
vh = version + hash
return base58.b58encode(vh + double_sha256(vh)[:4])
在:https://github.com/bitcoin-abe/bitcoin-abe/blob/3004fe4bad6f64d4c032c735ee23bf9f052d825b/Abe/util.py
当我通过该函数运行pubkey_hash时,我没有得到地址的预期结果。例如,使用以下pubkey_hash:62E907B15CBF27D5425399EBF6F0FB50EBB88F18
我应该得到:1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa
但我得到:6GEZdxx5UiTk3U3LaLfsWwRaFAvXEpPNS5R4mqsJDXVJcTNNngTyB5i9S76MLTq
我创建的脚本是:
import util
hash = '62E907B15CBF27D5425399EBF6F0FB50EBB88F18'
print util.hash_to_address("00", hash)
任何想法或是否有其他可以正确做到的事情?
Appleman1234指出了我正确的方向:
import util
hash = '62E907B15CBF27D5425399EBF6F0FB50EBB88F18'
hash = '00' + hash
print "Util: ", util.hash_to_address("", hash.decode('hex'))
答案 0 :(得分:2)
您未获得预期结果的原因是编码。
Python 2的正确代码
import util
hash = '62e907b15cbf27d5425399ebf6f0fb50ebb88f18'
print util.hash_to_address("00".decode('hex'), hash.decode('hex'))
Python 3的正确代码
import util
import binascii
hash = '62e907b15cbf27d5425399ebf6f0fb50ebb88f18'
print util.hash_to_address(binascii.unhexlify("00"), binascii.unhexlify(hash))
decode和unhexlify函数将十六进制ASCII表示转换为二进制字节字符串。
您遇到的问题是二进制字符串的散列和其十六进制ASCII表示的散列是两个不同的散列。