以太坊:不断进击的以太坊:EIP-1559 之后的 EIP-3074

?? Ropsten 测试网已于 6 月 24 日上线,区块高度为 10,499,401。

?? 自部署以来,约有 88,500 个测试网以太坊被烧毁,价值 1.776 亿美元。

?? 大约在 Eth3 启动的同时,价值 2 亿美元的 10 万以太坊已经被存入 Eth3 的质押合约。

备受期待的以太坊改进提案 EIP-1559 最终部署在 Ropsten 测试网,用于以太坊即将到来的伦敦升级。几天前,伦敦硬分叉的三个以太坊测试网发布日期公布。以太坊核心开发者 Tim Beiko 宣布 Ropsten、Goerli 和 Rinkeby 测试网的区块高度已经确定。Ropsten 的高度为 10499401,已于 6 月 24 日推出。另一方面,Goerli 在 6 月 30 日,Rinkeby 将在 7 月 7 日。

虽然伦敦硬分叉有 5 个以太坊改进提案,但 EIP-1559 已经吸引了所有的注意力。新的升级预计将消耗网络上的交易费用。据 EIP-1559 跟踪网站 Watch the Burn 报道,自从 Ropsten 测试网在伦敦进行升级后,约有 88500 个测试网以太坊被烧毁,价值 1.776 亿美元。然而,EIP-1559 所燃烧的大量以太坊再次引发了 Eth3 大修通货紧缩的讨论。由于燃烧机制,以太的燃烧速度比流通的供应更快。这可能对 ETH 的价格非常有利。

Ariane Capital:客户对加密货币的“需求不断增长”:金色财经报道,专注于技术领域的欧洲家族办公室 Ariane Capital 表示,其客户对加密货币的“需求不断增长”。联合创始人Benjamin Guez指出,该公司自 2014 年以来一直涉足加密货币市场,投资于加密行业并支持其发展,并提供法律架构和开设托管等服务。Guez 进一步指出,他们的客户一直在寻求长期定向投资,为了应对这种不断变化的需求,该公司正在推出主动管理基金 ARBA SPIN,基金将风险管理方法与现有的市场工具(例如期货或期权)结合使用。在推出后的第一个月,与低迷的加密市场表现相比,ARBA SPIN 收益率为 +12.5%。(Bitcoinist.com)[2022/1/4 8:22:25]

然而,EIP-1559 并不是以太坊社区关注的唯一 EIP。EIP-3074 是社区在升级中高度期待的另一个改进提案。根据 David Mihal 和他的推文,以太坊忽视的一个主要安全问题是 ERC20 的批准。他补充说,他已经推动了 ERC777,他们修复这一问题的唯一机会是 EIP-3074。这一以太坊改进提案将允许用户在一次交易中批准转账、执行操作和撤销批准。

此前,以太坊开发者注意到 EIP-1559 的设计并不是为了降低 gas 成本:但许多人仍然相信,该提案肯定会大幅降低 gas 成本。这甚至可能使矿工的收入减少 50%,导致「矿工起义」,但最终以失败告终。尽管如此,伦敦的升级预计将促进以太坊的看涨趋势。知名加密分析师 CryptoQuant 指出,大约在 Eth3 推出的同时,价值 2 亿美元的 10 万以太坊已经存入 Eth3 的质押合约。目前,超过 5% 的 ETH 供应量被锁定,价值约 117.5 亿美元。

CoinShares CSO:比特币和加密货币的投资配比正在不断增加:CoinShares的CSO Meltem Demirors分析了第一季度创纪录的加密货币流入量,她表示,黄金ETP在过去两个季度中有200亿美元的流出,而加密货币ETP却有70亿美元的流入量。这说明比起黄金,投资者想要加密货币。此前消息,第一季度加密货币基金流入量创历史新高,达到45亿美元,打破了2020年第四季度39亿美元的季度记录。(CNBC)[2021/4/8 19:57:07]

当我们想要发送代币到智能合约时,通常必须做两个交易:第一笔交易 approve 是花费我们的代币的合约,第二笔是 transferFrom 将代币发送到合约的交易。

EIP-3074 通过引入一种智能合约的方式来在外部拥有的账户 (EOA,或简单地说一个常规以太坊地址) 中发送交易,来解决问题。

这个 EIP 介绍了两个 EVM 指令 AUTH 和 AUTHCALL。第一个设置*authorized*基于 ECDSA 签名的上下文变量。第二个发送呼叫作为*authorized*。这实质上将 EOA 的控制权委托给了 [a] 智能合约。

Gemini联合创始人:比特币是新兴的、不断发展的、并准备接过价值存储的衣钵:金色财经报道,1月21日消息,Gemini联合创始人Cameron Winklevoss在推特上表示,美元是一块正在融化的冰块。黄金是恐龙。而比特币是新兴的、不断发展的、并准备接过价值存储的衣钵。[2021/1/21 16:38:47]

AUTH 和 AUTHCALL EVM 指令 (也称为操作码),让智能合约基于已签名的消息授权 EOA,并从该 EOA 发送交易 (「调用」)。这带来了很多可能性,比如:

赞助交易 (也称为元交易):从另一个账户支付交易的 gas。这也将允许我们从一个没有任何以太的地址发送代币。

批量交易:在一个调用中发送多个交易。这保证了在同一个区块中执行两个或多个交易,还可以降低交易费用。

改进的用户体验 (UX):例如,我们可以在单个交易中调用 approve 和 transferFrom。

与这些问题的现有解决方案不同,EIP-3074 不需要智能合约钱包。我们可以简单地将交易发送给执行交易的所谓调用者。调用者是无状态的、无需信任的智能合约,它们不要求我们预先将余额发送给合约。EIP-3074 也没有引入新的交易类型。通过只引入两个新的 EVM 指令,它在技术上应该更容易实现。

BB:依旧为不断壮大的团队和未来道路感到兴奋:Block.one CEO BB(Brendan Blumer)刚刚发推文表示:“看到人们离开总是让人难过,但我和以往一样为我们不断壮大的团队和未来的道路感到兴奋。改变带来机遇!”昨日消息,BM已辞去EOS的CTO职务。[2021/1/11 15:49:17]

EIP-3074 定义了两个新的操作码,可以从智能合约中调用:

AUTH (0xf6) -根据签名和提交授权外部拥有的帐户。它接受四个输入参数:commit 和签名的 yParity、r 和 s。

AUTHCALL (0xf7) -在授权的 EOA 上下文中发送调用 (交易)。它接受 8 个输入参数:gas、addr、value、valueExt、argsOffset、argsLength、retOffset、retLength。这类似于现有的 CALL 操作码。

为了授权一个 EOA,我们需要一个来自该 EOA 的签名消息。调用 AUTH 的智能合约可以从消息签名中恢复签名者,然后将消息签名设置为 authorized EVM 上下文变量。现在,无论何时智能合约调用 AUTHCALL,调用者都被设置为授权地址。当被调用的智能合约调用 CALLER(例如,通过 Solidity 的 msg.sender) 时,这现在是授权 EOA 的地址,而不是执行调用的智能合约调用者的地址。

河北金融学院教授赵永新:区块链在传统金融领域、新金融领域的应用不断向纵深推进:2021年1月8日,《CBC100》特邀亚洲区块链产业研究院副院长、河北金融学院教授、工信部区块链产业人才智库专家、全国优秀创新创业导师赵永新教授为我们带来《区块链与金融创新》的主题分享。赵教授表示,区块链在传统金融领域、新金融领域的应用不断向纵深推进。区块链技术会推动银行、证券、保险,基金信托等金融业态的发展,通过区块链技术可以实现不同政府、金融机构、企业等不同主体之间的数据共享,建立数据信任,助力金融机构更好地服务实体经济,降低成本,降低金融风险。另外,赵教授还向大家详细讲解了区块链的四种技术的主要原理,即分布式记账技术、共识机制、非对称加密和智能合约及其重要价值。[2021/1/8 17:40:35]

发送一个或多个交易的基本流程如下所示:

一个基本的 EIP-3074 流程,其中调用者契约发送多个交易。

EOA 签署授权信息;

EOA 或其他 gas 支付人将交易数据和授权信息发送给调用者合约;

调用者合约使用 AUTH 执行授权,并使用 AUTHCALL 发送交易。

谁将交易发送到合约中并不重要,只要 EOA 的签名是有效的。这使得其他人 (或另一个帐户) 可以发送交易。

为执行授权,EOA 必须以特定格式签署消息:

它由三部分组成:一个魔术字节 (0x03)、填充到 32 字节的调用者地址 (将执行授权的智能合约的地址) 和 32 字节的提交。

提交描述了 EOA 提交的对象,并且可以根据调用的某些属性 (如地址、值) 进行计算。调用者合约可以根据提供的属性重新计算提交,如果这些字段正确,则执行授权。

例如,假设我们想要发送以下交易 (表示为 JSON):

我们可以哈希这些字段 (例如,以一种确定的方式将它们连接在一起,或者使用 EIP-712 之类的东西) 并将其用作提交。

我们可以在智能合约中提供要发送的交易和授权消息的签名,如此 JSON 数据所示。合约函数可以是这样的:

智能合约重新计算提交交易,并将此提交 (连同签名) 提供给 AUTH 调用。这将尝试恢复签名者的地址,如果提交无效,将从签名中恢复错误的地址,这意味着交易将失败。

调用者完全负责确保此提交是安全的。我们可以简单地用 0x0 将消息签名为提交,并给予智能合约对 EOA 的完全访问权。EIP-3074 以前的版本包含了一个更严格的提交格式,包括像重放保护之类的东西,但后来为了更灵活而被删除了。因此,信任与我们交互的调用程序非常重要。

EIP-3074 能够基于签名更改 CALLER,从而显著地改变了 EVM 的工作方式。这可能会在新合约和现有合约中引入潜在的漏洞。因此,EIP-3074 被审计。

下面解释了一些可能的安全问题。由于这些不同的原因,EIP-3074 建议只与受信任的调用者进行交互。

如上所述,EIP-3074 没有为提交定义标准化的格式。调用者可以自由地以他们想要的任何方式实现这一点。这意味着调用者完全负责提供足够的保护,以防止 (例如) 重放攻击。

如果提交不包含某种随机数,则可以简单地获取签名消息并将其再次发送给调用者。恶意调用者可以通过根本不验证提交来获得对 EOA 的控制。我们在签名消息时应该始终小心。

通过在授权消息中包含调用者的地址,EIP-3074 具有防止重放攻击的基本保护。这样就不可能在另一个调用者上重放一个调用程序的授权消息。

EIP-3074 明确地指出,调用程序必须是不可升级的。如果调用程序是可升级的,则有人可以部署该调用程序的另一个版本,该版本不验证提交,从而给予合约对 EOA 的完全控制。

目前,智能合约可以使用 require(tx.origin == msg.sender),它检查一个交易是否从 EOA(而不是另一个合约) 发送。这允许简单的重入预防,因为它防止合约调用函数。

EIP-3074 也允许 tx.origin 成为授权消息的签名者。即使调用是由智能合约 AUTHCALL 执行的,调用者执行的任何 s 也会导致 tx.origin == msg.sender 为真,从而可能引入重入攻击。EIP-3074 提到:「[…] 本 EIP 的作者没有找到任何这种形式的重入保护的例子,尽管搜索并非详尽无遗。」

EIP-3074 为以太坊带来了许多令人兴奋的新可能性。AUTH 和 AUTHCALL 允许 EOA 将帐户的控制权委托给智能合约调用者,从而使发送批量交易、赞助交易等成为可能。不过,它对以太坊上的交易工作方式带来了一些重大变化,所以在 EIP-3074 在主网上被激活之前,还需要对安全性进行更多思考。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:0ms0-1:30ms