Python区块链Creating Miners教程
目录
- 消息摘要函数
- 挖掘函数
- 第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的资料请关注我们其它相关文章!