EIP-712是一种更高级、更安全的交易签名方法。我们可以在Uniswap V2的Periphery 合约中看到EIP-712的实现。
但对于EIP-712却很难被我们普通人所理解,本文就是根据一个示例来具体体验EIP-712,以达到对其的更好理解。
在GitHub中有许多文章和示例解释和展示了如何使用EIP-712,但在理解它作为一个整体是如何工作的以及前端代码和智能合约是如何关联的方面有很多困难。这是EIP712的一个示例(不是解释)。先决条件和使用的版本。
Solidity基础知识
npm 7.19.1
节点 16.2.0
Metamask 9.8.4
truffle 5.4.0
EIP-712是一种更高级、更安全的交易签名方法。使用该标准不仅可以签署交易并且可以验证签名,而且可以将数据与签名一起传递到智能合约中,并且可以根据该数据验证签名以了解签名者是否是实际发送该签名的人要在交易中调用的数据。
一个神秘NFT巨鲸以超过400万美元购买了Chromie Squiggles #7583和#2855:9月23日消息,一个神秘NFT巨鲸以超过400万美元的价格购买了Chromie Squiggles #7583和#2855,Chromie Squiggles是最知名的Art Blocks NFT系列之一,最近在 NFT 销售排行中名列前茅。从交易情况来看,这位巨鲸是一位狂热的艺术积木收藏家,旗下投资组合价值已经达到2400万美元,总计包括11个不同系列的115个NFT,其中有97个Art Blocks NFT。除了Chromie Squiggles,这位NFT巨鲸收藏家也非常喜欢Art Blocks Ringers系列收藏品,以及Ethernal Pump #41、Fidenza #859 和许多Subscapes NFT。(DappRader)[2021/9/23 17:00:05]
EIP-712提出了数据的标准结构和从结构化消息生成散列的定义过程。然后使用此散列生成签名。通过这种方式,为发送交易生成的签名与为验证身份或任何其他目的生成的签名之间就有了明显的区别。EIP-712草案将签名方案背后的动机表述为:
数据:比特币交易确认时间在一个月之内下降97%:Blockchain.com数据显示,过去一个月,确认比特币交易所需的平均时间大幅下降。这一指标在5月16日达到了年度高点,约340分钟,现在,交易平均时间降至7.88分钟,下降了97.68%。此外,比特币交易费也在2020年减半后达到年内高点后继续下降。(Cryptopotato)[2020/6/15]
提高链上使用的链下消息签名的可用性。我们看到越来越多的人采用链下消息签名,因为它节省了gas,减少了区块链上的交易数量。
EIP-712是类型化结构化数据的哈希和签名的标准,而不仅仅是字节字符串。它包括一个
编码函数正确性的理论框架,
与solid结构相似并兼容的结构化数据规范,
安全哈希算法用于这些结构的实例,
声音 | POC生态布道者虫哥:POC共识是一个可以共享的共识机制:由FINWISE 主办的全球科技金融高峰论坛在香港举办,POC生态布道者、HPOOL矿池创始人虫哥在会上表示:区块链行业里众多的POW共识算法将会对整个社会造成极大的能源浪费,而POC将会完美解决以上问题,POC是一个共享的共识机制,POC挖矿共享一个数据库,它的网络能够支撑上千种数字货币同时进行挖矿,未来所有加密货币的发币权和铸币权用一套共识机制就能完成 ,且无论单币种的市值多少,都可获得价值数十亿、百亿的基于手机内存或硬盘容量构成的全球化分布式随机哈希数组成的数据库支持共识的安全,这将是对整个区块链行业的一个巨大变革。[2019/5/29]
在可签名消息集中安全包含这些实例,
一个可扩展的域分离机制,
新的RPC调用eth_signTypedData,
声音 | IMF何东:央行数字货币可能是货币发行形态很重要的一个里程碑:据腾讯财经消息,国际货币基金组织(IMF)货币及资本市场局副局长何东出席“2018全球金融科技(北京)峰会时表示,央行数字货币可能是货币发行形态很重要的一个里程碑,在数字经济的时代,央行也应该与时俱进,对他自己货币的形态进行改良、调整,这样才能够在数字经济时代维护法定货币对公共政策起到的积极作用,包括在个人隐私的保护、可匿名性、反恐融资、反、货币政策、有效信息之间都可以起到比较良好的促进作用。[2018/11/17]
EVM中哈希算法的优化实现。
EIP-712的实现可以在Uniswap V2的Periphery 合约中看到,它通过许可移除流动性,最终调用Uniswap V2 Core中的方法来完成这一操作。
前端的签名被传递给Periphery 中的方法,签名被用来代表Core中使用该方法的用户批准Router合约。
金色财经现场报道北京鑫星伊顿技术服务股份有限公司CEO金岩石:比特币、区块链代表的是一个全新的财务体系:金色财经现场报道, 在2018中国区块链高峰论坛峰会现场北京鑫星伊顿技术服务股份有限公司CEO金岩石表示,“区块链就是分布式账本,理解这一点只是幼儿园毕业了。比特币、区块链代表的是一个全新的财务体系,他将挑战所有企业,世界上最早的记账方法是流水账,第二代记账是复式记账(透而不明),第三代记账是分布式账本,过去不可更改,未来无限开放,人人都有查账权,多点记账将实现真正公开透明。”[2018/5/20]
我们的示例将使用EIP-721提案用数据(地址、storedData的值和截止日期)签署交易,这些数据用于更改合约中变量的值。
如果签名和散列给出了签署人的地址,并且没有超过截止日期,则更改storedData的值。
这是一个无用的例子,但理解了它将确保您可以在其他地方使用该标准。正确使用 EIP-712 是创建一个 ERC20 许可证,就像 Uniswap 团队所做的那样。
继续克隆 truffle 的react box。
我们将根据需要简单地调整和添加代码,以使EIP-712正常工作。
数据是EIP-712中最关键的部分。这些要签名的数据必须符合预定义的格式。它必须有一个EIP712Domain和要签名的数据(在我们的示例中设置)。两者的组合将被签名并发送给智能合约进行验证。
在EIP-712下签名的每个数据必须有一个EIP712Domain和另一个数据。这两者的结构可以是任何东西,但必须在JS代码和SC代码上相同。
当使用该提案时,EIP712Domain的结构是一个被广泛接受的标准。
EIP-712 数据标准
EIP712Domain有一些参数,这些参数指定在哪个网络和哪个特定合约上将用于验证签名。另一份具有相同代码的合同将无法验证该签名。
让我们添加一个按钮,当单击该按钮时,将弹出元掩码,使用eth_signTypedData_v3方法对数据进行签名。
一旦签署了上面定义的数据使用eth_signTypedData_v3方法我们得到了签名和签名分割成其r, s,和v组件并将其发送到智能合约将使用ercrecover这些参数和数据哈希恢复签名者的公钥。
拆分签名
编写智能合约。
就像我们定义了包含EIPdomain和要签名的数据的JS代码一样,智能合约也需要两个变量来表示每个EIPdomain的散列数据和我们的数据(在本例中是设置数据)。
使用 ercrecover
在UI端,我们对数据进行签名,并将r、s和v发送给智能合约。
上面的代码做了两件事,首先它散列数据并生成它们的散列。接下来,它使用该数据的散列(在SC中称为散列)和签名,使用ercrecover方法生成签名者的公钥。
上面显示的数据的两个kecak哈希值应该类似于在out JS代码中定义的数据结构。如果两者不同,则无法恢复签名者的地址。
签名数据的结构
将infura中的助记符添加到truffle-config.js文件(第3行),并指定部署者的地址(第18行)。上面的例子使用了rinkeby testnet,但是任何测试都可以使用,并查看truffle文档来部署到其他测试网。
然后部署合同。部署后复制simplestorage的地址,替换为verifyingContract下app.js第76行的地址。
部署代码片段
进入client目录,运行npm run start启动react应用。
按下' Press to sign '按钮,然后在元掩码弹出的签名请求上签名。接下来,确认交易以设置智能合约上的值。
交易完成后,刷新webapp以查看所反映的变化。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。