Python区块链 - Creating Miners

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

消息摘要函数

我们将编写一个名为 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"开头,当然,它可能需要更多次迭代.如您所见,具有更强处理能力的矿工将能够更早地挖掘给定的消息.这就是矿工们为了赚取收入而相互竞争的方式.

现在,我们准备为区块链添加更多区块.让我们在下一章中学习这一点.