ERO:金色观察 | 一文看懂ERC-4337账户抽象_SERO

文/Jake&Stake,BanklessDAO作者;译/金色财经xiaozou

在OpenZeppelin最近的审计之后,ERC-4337的“EntryPoint”合约在主网上线,你可以在身边的EVM上使用帐户抽象了。

但是什么是帐户抽象呢?为什么账户抽象很重要?

首先,介绍一点背景知识。如今,以太坊上有两种类型的账户:

外部账户。外部账户是以太坊用户最熟悉的账户,它们被用于发送交易、与DeFi应用程序交互、或买卖NFT。MetaMask、CoinBase和其他钱包应用程序等产品向用户提供了可使用的EOA。这些帐户发起交易,并拥有授权交易的私钥。

合约账户。这些是不受私钥控制的智能合约账户。它们具有关联代码,当用户发送有效的交易时,代码将执行交易。合约账户不能自己发起交易。为了向区块链写入数据,必须签署交易,而合约帐户不能这样做,因为它们没有私钥。

香港金融管理局探讨了香港更广泛的代币化债券的潜力:金色财经报道,今天,香港金融管理局(HKMA)发布了一份报告,详细介绍了区块链债券发行“Project Evergreen”,并探讨了香港更广泛的代币化债券的潜力。虽然报告中介绍了代币化的好处,但其目标是推动事情向前发展,因此它解释了一些摩擦和需要在市场层面进一步开展工作的领域。

金管局首席执行官余伟文在报告前言中表示,债券发行展示了DLT如何“提高债券市场的效率、流动性和透明度”。在谈到DLT债券发行平台的激增时,他表示“至关重要的是考虑不同的解决方案如何相互连接和交互以及传统系统如何避免碎片化。”[2023/8/24 10:39:52]

帐户抽象的目的是不需要使用EOA发起交易,而是允许用户使用合约帐户执行交易,开启帐户的设计空间和可定制性。

用户可以为他们的抽象帐户实施任何授权逻辑。

多重签名

非ECDSA验证

金色财经行情播报丨BTC上冲回落 多空力量并未统一:据火币行情显示,今日BTC行情上冲回落,上午最高触及9236.68USDT后开始震荡下滑。日线图9150USDT区间平台突破失败,目前价格回归平台,均线MA5趋同,9200USDT上方压力依然构成打压。4小时图均线聚拢,但多空力量并未统一,1小时图均线MA30构成支撑。时间接近月底,波动或将扩大打破目前窄幅震荡局面。截至18:30,主流币的具体表现如下:[2020/6/30]

优化的隐私解决方案

想要提款限制?可以!

想要帐户恢复以防丢失私钥?可以!

想要使用你选择的ERC20代币支付交易?可以!

帐户抽象概念至少在2017年就已经出现了,并且已经有了一些实现尝试。

EIP-86

EIP-2938

EIP-3074

金色晨讯 | 消息人士:杨作兴被报案调查是詹克团遭罢免前直接下令执行:1.以太坊2.0测试网发布至少还需两周时间。

2.消息人士:杨作兴被报案调查是詹克团遭罢免前直接下令执行。

3.欧洲央行官员:欧洲央行已在研究数字货币的技术。

4.联想发布《区块链供应链协同应用白皮书》。

5.信通院发布《区块链白皮书(2019年)》,中国区块链专利申请数量居全球第一。

6.金山云一次性通过2019可信区块链测试,排名第一。

7.百度宣布“区块链智慧城市”规划,智能医疗、智能司法、智能交通、智能政务四大试点已在落地当中。

8.顺丰应用区块链技术为羊肉溯源。

9.京东推出“宙斯盾2.0”系统,运用区块链等技术实现SKU管理。

10.央行上海总部:将运用区块链技术提高企业整体融资效率。

11.中国集团公司促进会区块链分会正式发布《2018-2019世界500强企业布局区块链白皮书》。

12.央行前行长周小川:央行数字货币主要聚焦于中国,首先选择在票据交易、贸易融资两个系统做试点。

13.蚂蚁金服开放联盟链正式进行公测。

14.俄罗斯央行行长:正研究多国的数字货币,但不支持任何私人形式的加密货币。[2019/11/9]

然而,上述每一个协议都需要共识改变,一些现有的关于可扩展性的共识层更新是优先事项。因此,我们只有继续沿着这个方向继续走下去才能看到协议级别的帐户抽象。

金色财经现场报道 金色财经合伙人佟扬:区块链是面向全球的创新技术,需要用兼容并蓄的目光看待它:金色财经现场报道,在2018FINWISE东京纷智峰会上,进行以《区块链媒体在数字时代的角色定位》为题的圆桌论坛,金色财经合伙人佟扬指出:区块链是面向全球的创新技术,需要用兼容并蓄的目光看待它,作为新鲜科技媒体,需要加强技术型报道,向外界传达准确的信息。[2018/5/22]

然而,EIP-4337没有共识层变化。相反,4337引入了一个智能合约系统和一个名为“UserOperations”的伪交易。

UserOperations

UserOperations由用户提交到UserOperation内存池,并由“Bundlers”收集到“捆绑交易”中。这些Bundlers可以是选择处理这些交易的区块提议者或区块建设者。像Stackup、Alchemy、Biconomy、Blocknative、Etherspot和CandideWallet这样的实体已经进行了Bundlers的建设和部署。

金色财经现场报道 Universal Labs创始人Keda Che:区块链会完全改变供应链:在2018FINWISE东京纷智峰会上,Universal Labs创始人Keda Che:区块链会完全改变供应链,它并不只是把数据库结合在一起,而是把所有生态的价值,激励制度结合在一起,让所有参与者受益,而且这个系统更加透明。我们可以看到它在供应链领域的一些新发展。[2018/5/21]

捆绑交易被发送到名为“EntryPoint”的智能合约,该智能合约通过指定的智能合约钱包验证每个UserOperation。这些钱包必须实现两个功能:

validateUserOps

execute

EntryPoint合约将调用每个智能合约钱包的validateUserOps来确定交易是否有效。智能合约可以随心所欲地实现这个功能,支持上述的一些可定制性。

或者,EntryPoint合约可以使用签名聚合器。抽象帐户信任此合约以创建UserOperation签名,该合约还被Bundlers用于创建一个“aggregateSignsignature”,它是多个UserOperation的签名。这将众多签名转换为一个值,压缩验证所需的数据。这对于占用大部分数据成本的rollup来说尤其有用。

EntryPoint合约将在“handleOps()”进程中使用该聚合器合约来验证聚合签名。

如果UserOperation有效,EntryPoint将调用抽象帐户上的execute来执行所需操作。请注意,这些“抽象账户”就是智能合约。

EntryPoint合约

Entry?Point合约只有一个,这就是为什么Openzepplin的审计是重磅新闻。该合约将作为所有这些抽象帐户的中央信任锚点。

Entry?Point合约分离了交易验证和执行的过程。该合约使用两条路径来验证用户操作。

handleOPs

handleAggregatedOps

以上两个函数都将使用UserOp提供的参数创建一个帐户,并使用指定的抽象帐户验证UserOp。

最后,Entry?Point合约将通过在帐户上调用“execute”来执行UserOp,并将UserOp的calldata作为参数传入。然后,该帐户使用给定的参数执行所编程的任何操作。

基于Entry?Point的方法清晰地分离了验证和执行过程,允许帐户处理执行。所有这些使用户能够以一种可预测且精妙的方式与帐户交互,而不需要帐户所有者发起交易。

Paymasters

ERC还推出了“paymaster”概念。这是一个合约,将通过支付ETH来支持用户的交易。作为交换,用户通过向Paymaster发送预先指定的ERC-20代币来支付他们的交易。

以上是对ERC-4337细节的综述。还有很多很酷的细节,我们没有时间进行讨论,比如:模拟、捆绑规范和首次帐户创建等。

结论

对以太坊用户来说,这是一个巨大的用户体验改进。dApp可以支付用户的gas费,这对非加密原生用户来说是一个很好的进入加密世界的工具,交易可以批量处理,还有“payment?sessions”,这样你就不再需要批准每一笔交易了。

帐户抽象可以提高隐私工具的效用,允许用户使用他们想要的任何代币支付交易,并允许用户与区块链交互而无需处理私钥。今天你若丢失了私钥则意味着你的钱也丢失了。

而在一个账户抽象的世界里,丢失私钥并不意味着失去一切。

请特别注意围绕Visa的兴奋之情。他们的团队通过使用pull-based交易和自我托管钱包,发布了一种自动支付的设计。对于那些希望使用区块链进行经常性支付以补充服务的公司来说,这一直是一个巨大的问题。

以前,付款必须由付款人发起,但通过帐户抽象,服务提供商可以为他们的服务收费,而无需你自己进行交易。就像自动支付信用卡账单一样。帐户甚至可以被编程为在任何时间内接收发票,因此你可以设置订阅服务的时间限制。

钱包可以进行配置,这样你就可以有备份账户了,还可允许某些服务的更改。用户甚至可以在不知情的情况下与区块链进行交互。帐户创建可以由帐户发起人处理,所有用户所要做的就是使用web2类型的用户体验来管理自己的钱包。

简而言之,帐户抽象为以太坊的安全性和去中心化增加了效用。这是个大工程,而我们才刚起步。

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

大币网

[0:15ms0-5:749ms