哈希函数在区块链中的应用

释放双眼,带上耳机,听听看~!
比特币区块包含了区块头部和一些比特币交易。一个区块上所有交易的哈希值构成了该区块默克尔哈希树的叶子结点,默克尔哈希树的根节点保存在区块头里面,因此所有交易与区块头部绑定在了一起。

前几节课我们对哈希函数已经有了一个很完整的认知,今天这节课我们来细说哈希函数在区块链中的应用~

以太坊用户地址的生成

第一步:生成私钥 (private key)

产生的256比特随机数作为私钥(256比特 16进制32字节): 
18e14a7b 6a307f42 6a94f811 4701e7c8 e774e7f9 a47e2c20 35db29a2 06321725

第二步:生成公钥 (public key)

利用将私钥(32字节)和椭圆曲线ECDSA-secp256k1计算公钥(65字节)(前缀04||X公钥||Y公钥): 
04 ||50863ad6 4a87ae8a 2fe83c1a f1a8403c b53f53e4 86d8511d ad8a0488 7e5b2352 || 2cd47024 3453a299 fa9e7723 7716103a bc11a1df 38855ed6 f2ee187e 9c582ba6

利用Keccak-256算法计算公钥的哈希值(32bytes):
fc12ad81 4631ba68 9f7abe67 1016f75c 54c607f0 82ae6b08 81fac0ab eda21781

取上一步结果取后20bytes即以太坊地址:
1016f75c54c607f082ae6b0881fac0abeda21781

第三步:输地址 (address)
0x1016f75c54c607f082ae6b0881fac0abeda21781

默克尔哈希树

比特币区块包含了区块头部和一些比特币交易。一个区块上所有交易的哈希值构成了该区块默克尔哈希树的叶子结点,默克尔哈希树的根节点保存在区块头里面,因此所有交易与区块头部绑定在了一起。

哈希函数在区块链中的应用

挖矿难度的设置

比特币难度是对挖矿困难程度的度量,即指:计算符合给定目标的一个哈希值的困难程度。

difficulty = difficulty_1_target / current_target

difficulty_1_target的长度为256比特, 前32位为0, 后面全部为1 ,一般显示为哈希值,

0x00000000FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF

difficulty_1_target表示btc网络最初的目标哈希。current_target是当前块的目标哈希,先经过压缩然后存储在区块中,区块的哈希值必须小于给定的目标哈希值, 表示挖矿成功。

数字签名

比特币需要利用公钥进行加锁,利用私钥签名进行解锁,从而实现数字货币的交易。解锁过程实际上是利用ECDSA算法的产生数字签名。给定交易信息m,签名过程如下:

选择一个随机数k
计算点R= k*G= (xR, yR) ,计算r=xR mod n
利用私钥d计算s=k-1*((H(m) – d*r)) mod n
输入签名(r, s)

软件发布

哈希函数在区块链中的应用

挖矿软件发布信息示意图

哈希函数在区块链中的应用就讲到这里啦,下节课我们将开启全新篇章的学习,敬请期待!

郑重声明:本站主要用于区块链行业信息资讯传播,促进行业健康发展,部分信息转载自互联网,文章版权归原作者所有 如作者信息标记有误 请第一时间联系我们修改或删除 谢谢
关键词:
哈希函数  区块链应用  

生成海报

给TA买糖
共{{data.count}}人
人已赞赏
百科

详解常用哈希函数(SM3算法)

2020-10-10 9:40:59

百科

稳定币到底是什么?有什么作用和意义?

2020-10-10 11:50:11

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
免责声明:本站所有资讯仅代表作者个人观点,与平台立场无关,且不构成任何投资理财建议。
This is default text for notification bar