目录
  • 消息摘要函数
  • 挖掘函数
    • 第1步
    • 第2步
    • 第3步
  • 测试挖掘函数

    为了实现挖掘,我们需要开发一个挖掘功能.挖掘功能需要在给定的消息字符串上生成摘要并提供工作证明.让我们在本章讨论这个.

    消息摘要函数

    我们将编写一个名为 sha256 的实用程序函数来创建给定消息的摘要 :

    def sha256(message):
    return hashlib.sha256(message.encode('ascii')).hexdigest()

    sha256 函数将消息作为参数进行编码它为ASCII,生成十六进制摘要并将值返回给调用者.

    挖掘函数

    我们现在开发 mine 实现我们自己的挖掘策略的功能.在这种情况下,我们的策略是在给定消息上生成一个前缀为给定数字1的散列.给定的1的数量被指定为 mine 函数的参数,指定为难度级别.

    例如,如果指定难度级别为2,则在给定消息上生成的散列应该从两个1开始 – 如11xxxxxxxx.如果难度级别为3,则生成的散列应以三个1开始 – 如111xxxxxxxx.鉴于这些要求,我们现在将开发挖掘函数,如下面给出的步骤所示.

    第1步

    挖掘函数有两个参数 – 消息和难度级别.

    def mine(message, difficulty=1):

    第2步

    难度级别需要大于或等于1,我们使用以下断言语句 : 确保这一点;

    assert difficulty >= 1

    第3步

    我们创建前缀变量使用设定的难度级别.

    prefix = '1' * difficulty

    请注意,如果难度级别为2,则前缀为"11",如果难度级别为3,则前缀为"111",依此类推.我们将检查生成的消息摘要中是否存在此前缀.为了消化消息本身,我们使用以下两行代码 :

    for i in range(1000):
       digest = sha256(str(hash(message)) + str(i))

    我们继续添加一个新的数字 i 到每次迭代中的消息哈希并在组合消息上生成新摘要.由于 sha256 函数的输入在每次迭代中都会发生变化,因此摘要值也会发生变化.我们检查此摘要值是否高于前缀.

    if digest.startswith(prefix):

    如果条件满足,我们将终止 for 循环并返回摘要给来电者的价值.

    这里显示的是整个我的代码 :

    def mine(message, difficulty=1):
       assert difficulty >= 1
       prefix = '1' * difficulty
       for i in range(1000):
          digest = sha256(str(hash(message)) + str(i))
          if digest.startswith(prefix):
             print ("after " + str(i) + " iterations found nonce: "+ digest)
          return digest

    为了您的理解,我们添加了打印摘要的 print 语句值和在从函数返回之前满足条件所需的迭代次数.

    测试挖掘函数

    测试我们的迷你ng函数,只需执行以下语句 :

    mine("test message",2)

    当你运行上面的代码时,你会看到类似于下面和下面的输出;

    after 138 iterations found nonce:

    11008a740eb2fa6bf8d55baecda42a41993ca65ce66b2d3889477e6bfad1484c

    请注意,生成的摘要以"11"开头.如果将难度级别更改为3,则生成的摘要将以"111"开头,当然,它可能需要更多次迭代.如您所见,具有更强处理能力的矿工将能够更早地挖掘给定的消息.这就是矿工们为了赚取收入而相互竞争的方式.

    现在,我们准备为区块链添加更多区块.让我们在下一章中学习这一点,更多关于Python区块链Creating Miners的资料请关注其它相关文章!

    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。