Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

Python中的Base58Check编码

Posted on 2025-07-31

上一篇文章开头说:“比特币的钱包导入格式(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/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • eighty twenty
  • Elad Gil
  • Ellie Huxtable
  • Ethan Dalool
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Li Haoyi
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Maggie Appleton
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mind Matters
  • Mostly metrics
  • Naval Ravikant
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Rohit Patel
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Steph Ango
  • Steve Blank
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • Wes Kao
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme