钱包2.0时代:MPC钱包vs智能合约钱包_ROFI:BSP

原文作者:Chloe

在波哥大举办的 Devcon 6 大会中,Tomasz Tunguz 提到了 Web3.0  的一些统计数据:各主流公链 DAU 累计约为 250 万,而传统互联网的 DAU 为 50 亿,前者勉强够上后者的 0.05%。从供给侧来看,约有 1.6 万名开发者在 Web3.0 开发,而世界上开发者总数达到了 2700 万,Web3 开发者占卜不足 0.06%。因此,Web3.0 离 mass adoption 还有很远的距离。

钱包,作为 Web3.0 的入口,其用户体验直接影响到加密行业何时能迎来大规模化采用。尽管各大钱包在这方面卯足了劲,可在普通用户的眼里,钱包使用体验依旧不尽人意。托管钱包虽然易用,但是安全性是一个很大的隐患,钱包被盗事件层出不穷。自托管钱包虽然相对安全,但保管长长的助记词和私钥的方式与传统互联网的用户名 - 密码体系相比复杂了很多。据 Chainalysis  的研究报告显示,截止 2021 年约有 20% 流通中的比特币,因所有者不记得私钥而丢失。很多人可能会有疑问,为什么我们不能将传统的验证方式应用到 Web3.0 来呢?

Cardano正式推出Daedalus钱包2.4.0版本:10月28日,Cardano开发团队IOHK官方发推宣布,正式推出Daedalus钱包2.4.0版本。新版本继续对Cardano用户体验进行了改进,并带来很多新特性,如注池的饱和指示器。[2020/10/29]

为什么我们只能通过私钥的方式进行验证?为了回答这个问题,我们需要了一些背景知识和概念。首先是以太坊上的账户类型。以太坊一共有两种账户:外部账户和合约账户。合约账户就是智能合约,其代码由以太坊虚拟机来运行。而外部账户就是我们平常用来发起交易的钱包账户,它之所以被称为「外部」是因为这种账户本身是没有代码的,因此独立于以太坊虚拟机之外,由用户通过私钥进行控制。

图片来源: https://lh3.googleusercontent.com

合约账户虽然有自定义逻辑,但它是无法主动发起事务的。因此任何合约状态的改变都依赖外部账户来发起,并由外部账户支付 Ether。那如何验证事务的合法性呢?以太坊上的验证方式为检查事务的发起人和资产 (Ether) 的所有人,也就是这个外部账户的拥有者是一致的。因此用户需要通过钱包对交易进行签署。而以太坊默认的验证逻辑是中本聪 设计的 secp256k1,也正是通过此算法生了密钥对。签名的正确性可以通过验证该签名是否出自跟某个共钥对应的私钥检验,因此用户必须掌握这个私钥。这就是为什么无论如何优化钱包的用户体验也无法绕开私钥的问题。

动态 | TronLink波宝钱包2019年共发布27个版本,累计服务用户30万+:据TronLink波宝钱包年终报告数据显示,2019年TronLink已累计服务用户30万+;每天有1.3万+用户持续活跃在波宝钱包;共发布27个版本:包括多重签名、冷钱包、支持DAppChain和邀请好友等功能。TronLink波宝钱包是一款安全、全面、专业的波场钱包,也是目前波场TRON生态中用户量最大的去中心化钱包。[2020/1/9]

图片来源:https://www.ledger.com/academy/blockchain/what-are-public-keys-and-private-keys

前文提到,外部账户并不具备代码逻辑。如果想要引入更复杂的逻辑来实现其他的功能,比如多签等等,是无法在外部账户上直接进行的。那么,目前有什么样的方式可以解决此问题呢?笔者将介绍被认为最可行有效的两种解决方案:MPC 钱包和智能合约钱包。

MPC,全称为 Multi-Party Computation,是一种重要的加密安全措施。其包含了很多种技术方案,在本文的语境下主要指 MPC-TSS。而 MPC 钱包,是通过对私钥进行多方计算在链下实现「多签「、」跨链 「等等更复杂的验证方式。简单来说,就是将一个私钥打碎成多片,将私钥碎片交与一个去中心化的网络进行计算和加密。当需要私钥签名时,则将碎片再拼接起来形成一个完整的私钥。MPC 的核心思路为分散控制权以达到分散风险或提高备灾的目的,有效避免了单点失败等安全问题。

动态 | 10家主流交易所USDT钱包24h净提现5205.28万元:据金果子APP(JGZ.COM)官方数据,10家被监测的主流交易所在过去24h内,USDT钱包充值6.45亿元,提现6.97亿元,24小时净提现5205.28万元,近7日净提现1.87亿元;24h充提用户数1.71万人,较7日前下降27.92%。[2019/12/30]

图片来源:https://sepior.com/products/advanced-mpc-wallet

MPC 钱包「多方参与」的概念与「多签钱包」有些类似,但实际上,虽然都可以实现「多签」的功能,二者的实现途径是不一样的。之前我们所熟知的多签钱包,比如 Gnosis Safe 等等,是建立在智能合约上的钱包,合约中定义了验证逻辑,比如如果需要验证一笔交易,需要一个以上的私钥,或者五个中至少三个私钥进行验证。这类钱包属于后文即将提到的智能钱包的一种。而 MPC 钱包,则是将一个私钥分解成多个片段,验证过程只涉及到一个私钥。并且计算网络是链下的,与智能合约并无联系。

分析 | 10家主流交易所USDT钱包24h净提现7053.11万元,近7日提现逐渐增多:据金果子APP(JGZ.COM)官方数据,10家被监测的主流交易所在过去24h内,USDT钱包充值10.44亿元,提现11.15亿元,24小时净充值7053.11万元,近7日净提现3.71亿元;大盘震荡下跌,USDT提现逐渐增多。[2019/12/27]

智能合约钱包,正如其名,是基于智能合约而不是外部账户的钱包。市面上已经有不少的智能合约钱包,但因为这些智能合约是自定义的,缺乏统一的行业标准,且存在合约漏洞以及与其他合约兼容性等等问题未获得广泛的应用。最近,智能合约钱包又因为「账户抽象」提案 EIP-4337 的重大进展而再次成为了热议的话题。那么账户抽象到底是什么意思呢?实现了账户抽象后,又能给用户带来怎样全新的体验?在了解以太坊上的账户抽象之前,我们首先需要了解 CS 中抽象概念。

「抽象」是计算机科学最重要的概念之一,指在向外界提供必要的关键信息的同时隐藏其后台的实现细节,使得开发者在处理一个抽象层的任务时,只需要专注于这一个抽象层。举一个贴近生活的例子:当我们作为观众想使用电视机的时候,我们只需要熟悉作为电视观众需要了解的操作,比如如何打开和关闭电源、调整音量、切换频道、连接其他设备如游戏机、DVD 等等。观众并不需要了解电视内部的实现细节,比如电视是如何通过缆线接受信号,如何转换信号,如何将这些信号呈现在电视屏幕上等等。这些实现细节是造电视的人需要了解的。作为观众,我们只需要通过外部接口,比如电源按钮、遥控器、DVD 等控制电视。

动态 | 10家主流交易所USDT钱包24h净提现3231.67万元 以散户充提为主:据JGZ.COM官方数据,10家被监测的主流交易所在过去24h内,USDT钱包充值12.75亿元,提现13.07亿元,24小时净提现3231.67万元,近7日净提现1.1亿元;24h钱包充提金额同比下跌21.8%,但是充提人数较7日上升10.61%,说明充提多为散户。[2019/12/20]

账户抽象同理,我们作为钱包用户,仍需要考虑很多因素,比如 gas price、gas limit、事务阻塞等等复杂的费用逻辑。其根本原因是基于外部账户的钱包不能够被很好地「抽象」,直接导致用户需要处理很多本不应该由用户处理的问题。那如何解决呢?逻辑很简单,我们可以将外部账户和合约账户抽象,使外部账户更贴近合约账户,这样就可以通过智能合约赋予钱包更加复杂的逻辑。智能合约钱包能够实现的功能也不止「多签」这一个场景了。

图片来源:https://miro.medium.com/

如果 EIP-4337 能够实现以太坊账户的系统性升级,作为用户的我们能获得什么新的体验呢?理论上只要能通过智能合约代码定义的功能都能实现。首先,智能合约钱包可以通过非 secp256k1 的验证算法进行验证,用户不需要面对长长的密钥对和助记词。同时,智能合约还可以赋予密钥更多的逻辑。比如在多签的场景下,给每一个私钥定义不同的权限:50USDC 以下的交易需要私钥 A 签名,50USDC 以上的交易需要私钥 B 签名,超过 2000USDC 的交易需要私钥 ABC 共同签名等等。此外,通过移动端与区块链交互会变得更加容易,我们可以授权一个专属于手机的密钥,且可以定义这个密钥加上限制,比如只能与固定几个智能合约交互,或者智能验证数额较小的交易等。其他能够实现的功能还包括一键授权批量交易、交易黑名单等等。总之,智能合约钱包的想象空间非常大。

介绍完两种钱包,读者可能会产生疑问,这两种解决方案到底哪一种更好呢?笔者认为很难进行比较,因为 MPC 钱包和智能合约钱包本质上不在同一个层面解决问题。MPC 钱包是链下方案,既可以控制基于外部账户的普通钱包,也可以控制智能钱包。二者各有用例,并不冲突。因此,笔者将为大家分别列举两种方案的机遇和挑战。

MPC 钱包作为链下方案,并不涉及到以太坊共识层或合约层的改动,用户的使用成本更低,且在短期内更具可行性。此外,在一些特殊的使用场景比如跨链密钥等更具优势。智能合约钱包是以太坊的系统性升级,可以给用户带来更多全新的体验和用例。但账户抽象是一个需要「兴师动众」的大工程,要求其他智能合约、开发者、以及以太坊架构都配合升级。过大的实操难度使从 2015 年就提出的愿景到今天也没有完全落地。而智能合约钱包对于用户而言,最直接的问题就是钱包的使用成本将会提升,从创建钱包开始就需要支付费用。

笔者认为,智能合约钱包是我们的最终愿景,MPC 是短期内更可行的方案,且在一些特殊场景更具优势。因为成本问题,未来智能钱包在以太坊主网实现的可行性和可能性都较低。读者可以更多关注 Layer2  上的账户抽象和智能钱包进展。目前 EIP-4337 是最可行的账户抽象方案,已经有不少智能合约钱包项目在探索这条路径,智能钱包的全面落地可能比我们想象的更近。

IOSGVentures

企业专栏

阅读更多

金色早8点

区块律动BlockBeats

1435Crypto

金色财经

吴说区块链

比推 Bitpush News

blockin

Block unicorn

Foresight News

Odaily星球日报

Bankless

DeFi之道

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

金宝趣谈

[0:15ms0-8:247ms