上一篇文章开头说:“比特币的钱包导入格式(WIF)本质上是带有校验和的 Base58 编码。”更具体地说,WIF 使用Base58Check编码。
这篇文章将填补缺失的细节,并展示如何在 Python 中执行 Base58Check 计算。由于涉及编码问题,执行此操作可能会遇到多种困难。你必须计算哈希函数,这在概念上很简单,但你会遇到将字符串转换为字节、字节顺序、字节序等问题。而且在 Python 中,哈希的输出不是数字或字符串,而是一个必须以某种方式“消化”的对象。然后,你需要找到正确的语法来进行 Base58 编码。
这篇文章将逐步介绍本教程示例。
***
该示例表示采用 SHA256 哈希值
800C28FCA386C7A227600B2FE50B7CAE11EC86D3BF1FBE471BE89827E19D72AA1D
并得到
8147786C4D15106333BF278D71DADAF1079EF2D2440A4DDE37D747DED5403592
好的,我们开始吧:
>>> 从 hashlib 导入 sha256 >>> s = "800C28FCA386C7A227600B2FE50B7CAE11EC86D3BF1FBE471BE89827E19D72AA1D" >>> d = 字节.fromhex(s) >>> sha256(d).hexdigest().upper() '8147786C4D15106333BF278D71DADAF1079EF2D2440A4DDE37D747DED5403592'
这与我们应该得到的一致。
接下来,示例要求再次对结果进行哈希处理。我们必须对第一次哈希的字节进行哈希处理,而不是字符串表示。
>>> sha256(sha256(d).digest()).hexdigest().upper() '507A5B8DFED0FC6FE8801743720CEDEC06AA5C6FCA72B07C49964492FB98A714'
输出与示例所示我们应该得到的结果相符。
现在我们应该取前 4 个字节(由前 8 个十六进制字符表示)并将它们粘贴到我们s
存储的地址的末尾。
s += '507A5B8D'
最后我们应该将结果转换为Base58。
>>> 从 base58 导入 b58encode >>> b58encode(bytes.fromhex(s)) b'5HueCGU8rMjxEXxiPuD5BDku4MkFqeZyd4dZ1jvhTVqvbTLvyTJ'
这与示例中的结果相符。
Python 中的 Base58Check 编码一文最先出现在John D. Cook上。
原文: https://www.johndcook.com/blog/2025/07/30/base58check-python/