如何用python阐释工作量证明

发布时间:2021-10-14 14:44:06 作者:柒染
来源:亿速云 阅读:142

如何用python阐释工作量证明,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

了解比特币的都知道挖矿很耗电,这是因为比特币用到了工作量证明.

工作量证明是指系统为达到某目标而设置的工作度量方法.一开始是用在网络攻防上,大大提高攻击者的计算量,攻击成本也就上去了.
工作量证明需要由工作者和验证者两方共同完成.它有两层含义.

举几个例子

在计算机系统中,可以这样设计:
验证者给定一个随机字符串s,工作者必须找出一个数n,使得随机字符串拼上这个数n后的md5结果前面几位都是0.
即md5(s+n)的结果符合验证者的要求.工作者只能不停的穷举,找出这样一个数n.

下面上python代码.

工作方:

#coding=utf-8
from itertools import count
from hashlib import md5
msg = 'randomstring'
for i in count():
    hashid = md5(msg+str(i)).hexdigest()
    if hashid.startswith('0000'):
        print i,hashid
        break

输出39496 00001c48020e444f58a297a0785df5cf,即工作方需要md5()39496次.

而验证方只需要拿工作方给过来的n,进行一次md5即可验证.
即if md5(msg+str(n)).hexdigest()[:4] == '0000'.

因为md5用十六进制表示,每一位出现的概率是16.所以工作者要找到前面4位都是0平均需要16*16*16*16=65536次.
验证者可以根据自身需要来规定前面0的个数来控制工作者的工作量.想要对方耗多点电,那就多加几个0吧.

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

推荐阅读:
  1. 软件项目工作量估算方法解析
  2. 如如何使用journalctl命令?

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

python

上一篇:EasyScreenLive同屏功能组件支持自定义OSD的方法步骤

下一篇:.net如何实现GridView分页模板

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》