RC20-Permit(EIP-2612)下,如何避免 使用进行两步交易:授权+ transferFrom!
译文出自:登链翻译计划
译者:翻译小组
本文永久链接:learnblockchain.cn/article…
**今天是 2019 年 4 月在悉尼。**在这里我正在寻找悉尼大型大学大楼内的 Edcon Hackathon。感觉就像一个城市中的一个小城市。当然,我在综合大楼的尽头,我意识到要前往举办 Hackathon 的场地,我需要步行 30 分钟到另一端。在正式开始前几分钟,我在会场报名!
在所有参与者都生活和呼吸加密的情况下,建立了允许在一种自助餐厅中使用 DAI 进行付款的系统。这特别有用,因为 AlphaWallet 开展一项促销活动:向 Hackathon 参与者赠送 20 个促销 DAI(随后可购卖打折饮品),我已经下载了钱包和获得了 20 个 DAI,接下来找到自助餐厅就完美了...
事实并非如此简单。首先,步行 15 分钟即可到达大学城的中心。我终于找到了。我选择了午餐,很高兴尝试这个新的付款系统。在 2012 年之前,我已经在餐厅使用比特币付款,但这是我第一次使用 ERC-20 . 我扫描 QR 码,在 DAI 中输入要支付的金额,然后...
'没有足够的 gas 来支付交易费用。'
啊!所有的激动都消失了。当然,你需要 ETH 来支付 gas 费!我的新钱包有 0 ETH。我是一个 Solidity 开发人员,我知道这一点。然而,即使我也发生了。我的有 ETH 的计算机一直都在会场,所以对我来说没有解决方案。没有午餐,而是漫不经心地回到了会场,我对自己想。要使这项技术成为主流,我们还有很长的路要走。
从那时起,DAI 和 Uniswap 一直在朝着名为 EIP-2612 的新标准的方向发展,该标准可以取消 approve + transferFrom,同时还允许无 gas 通证转账。 DAI 是第一个为其 ERC-20 通证添加新的 permit
功能的公司。它允许用户在链下签署授权的交易,生成任何人都可以使用并提交给区块链的签名。这是解决 gas 支付问题的基本的第一步,并且消除了用户不友好的两步过程:发送 approve
和之后的 transferFrom
。
让我们详细研究一下 EIP。
总体而言,该过程非常简单。用户不在发起授权(approve)交易,而是对 approve(spender, amount)
签名。签名结果可以被任何人传递到 permit
函数,在 permit
函数我们只需使用 ecrecover
来检索签名者地址,接着用 approve(signer,spender,amount)
。
这种方式可用于让其他人为交易支付 gas 费用,也可以删除掉常见的授权(approve)+ transferFrom 模式:
之前方法:
用户提交 token.approve(myContract.address, amount)
交易。
等待交易确认。
用户提交第二个 myContract.doSomething()
交易,该交易内部使用 token.transferFrom
。
现在:
用户进行授权签名:签名信息 signature=(myContract.address,amount)
。
用户向 myContract.doSomething(signature)
提交签名。
myContract
使用 token.permit
增加配额,并调用 token.transferFrom
获取代币。
之前需要两笔交易,现在只需要一笔!
我们面临的主要问题是签名可能会多次使用或在原本不打算使用的其他地方使用。为防止这种情况,我们添加了几个参数。在底层,我们使用的是已经存在的,广泛使用的 EIP-712 标准。
使用 EIP-712,我们为 ERC-20 定义了一个域分隔符:
bytes32 eip712DomainHash = keccak256( abi.encode( keccak256( "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)" ), keccak256(bytes(name())), // ERC-20 Name keccak256(bytes("1")), // Version chainid(), address(this) ) );
这样可以确保仅在正确的链 ID 上将...
年少
个评论:
感谢您的善举,每一次解答会成为新人的灯塔。回答被采纳后获得20算力和相应LK币奖励。
什么是区块链和以太坊?在哪里使用?
Long
在以太坊区块链中使用代币
老虎or猫咪
私有以太坊上的NodeJs区块链
DEFI爱好者
在两个以太坊和Corda构建的独立区块链网络之间转移价值
YYF
以太坊社区是否准备好反对ASIC?
三地
以太坊上的 「BTC 一站式商店」?解析 BadgerDAO 产品特性与发展潜力
就像稳定币的发展将引领我们走向智能稳定币和无数效用一样,接下来可能发生的是比特币在以太坊上...
DEFI爱好者|2021.01.28
Ethereum Optimism 分阶段推出测试网,简单了解流程与参与方式
公共测试网预计在二月底启动,任何人都可以在其中部署合约并与之交互。转载《以太坊爱好者》原文...
Blockchain|2021.01.28
如何开发出好用的轻量级客户端?
大约 5 年前,我们开始构建 Trinity —— 以太坊网络上的新型 “轻量级客户端”。...
Angle|2021.01.27
GKR+Groth16与Groth16验证MiMC哈希的验证时间比较
原文标题:Prover time comparison of GKR+Groth16 vs...
区块技术花|2021.01.27
币圈丁钰:机会和信任一样,犹豫多一秒,机会就少一分。
前言: 机会和信任一样,犹豫多一秒,机会就少一分。最近客户都是忙着数钞票,买比特币,...
币圈丁钰|2021.01.26