Solidity极简入门|第二十八讲:Hash

文章介绍了哈希函数的关键性质,包括单向性、灵敏性、高效性、均一性和抗碰撞性。重点讨论了Keccak256在生成数据唯一标识、加密签名中的应用,并通过示例展示了其弱抗碰撞性和强抗碰撞性。
摘要由CSDN通过智能技术生成

Hash 的性质

一个好的哈希函数应该具有以下几个特性:

单向性:从输入的消息到它的哈希的正向运算简单且唯一确定,而反过来非常难,只能靠暴力枚举。

灵敏性:输入的消息改变一点对它的哈希改变很大。

高效性:从输入的消息到哈希的运算高效。

均一性:每个哈希值被取到的概率应该基本相等。

抗碰撞性:弱抗碰撞性:给定一个消息 x,找到另一个消息 x'使得 hash(x) = hash(x') 是困难的。

强抗碰撞性:找到任意 x 和 x',使得 hash(x) = hash(x') 是困难的。

Hash 的应用

生成数据唯一标识

加密签名

安全加密 

Keccak256

Keccak256 函数是 solidity 中最常用的哈希函数,用法非常简单:

d42203a3547725f52a0429732bbb2c29.jpeg

生成数据唯一标识

我们可以利用 keccak256 来生成一些数据的唯一标识。比如我们有几个不同类型的数据:uint,string,address,我们可以先用 abi.encodePacked 方法将他们打包编码,然后再用 keccak256 来生成唯一标识:

8e3fdaa820880cd691c2ac7cf2bd2784.jpeg

弱抗碰撞性

我们用 keccak256 演示一下之前讲到的弱抗碰撞性,即给定一个消息 x,找到另一个消息 x'使得 hash(x) = hash(x') 是困难的。

我们给定一个消息 0xAA,试图去找另一个消息,使得它们的哈希值相等:

a656d20b4229aa4f6cc93e39cfc4ee0c.jpeg

大家可以试个 10 次,看看能不能幸运的碰撞上。

强抗碰撞性

我们用 keccak256 演示一下之前讲到的强抗碰撞性,即找到任意不同的 x 和 x',使得 hash(x) = hash(x') 是困难的。

我们构造一个函数 strong,接收两个不同的 string 参数 string1 和 string2,然后判断它们的哈希是否相同:

1aaf108b9da35191d59767a117d5517d.jpeg

大家可以试个 10 次,看看能不能幸运的碰撞上。

总结

这一讲,我们介绍了什么是哈希函数,以及如何使用 solidity 最常用的哈希函数 keccak256。

eeb840ba641313f8bcb1334da7c838ef.jpeg

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值