详解Sui密码学中的钱包规范

CN
1 year ago

Sui遵循加密货币行业广泛接受的钱包规范,如BIP-32(及其变体,SLIP-0010),BIP-44和BIP-39。这些规范已经成为加密货币行业的普遍现象,作为用户管理账户密钥的一种手段。

目前,Sui接受使用Ed25519或ECDSA Secp256k1的签名交易。在Sui钱包和SDK中,Sui提供了一个灵活的接口来签署各种签署方案的交易。

密钥衍生方案

Sui遵循BIP-32来管理支持ECDSA Secp256k1签名方案的钱包。

BIP-32定义了分层的确定性钱包结构,以逻辑地关联一组钥匙。以这种方式对钥匙进行分组,减少了跟踪一个用户的大量私钥的开销。这种方法也让保管人在一个控制源下为每个用户账户分发不同的管理地址。

使用BIP-32将私钥的推导与公钥的推导解耦,实现了只看钱包的用例,即可以推导出一串公钥及其地址,而私钥可以保持离线签署。

Sui遵循SLIP-0010来管理支持Ed25519(EdDSA)签名方案的钱包。

Sui使用SLIP-0010是因为BIP-32最初是为具有初阶组的ECDSA设计的,而Ed25519曲线是基于h×ℓ的组阶,其中h是一个小的协处理器,ℓ是一个252位的素数。这是一个高级的技术细节,但Ed25519签名标准对私钥的低位和高位都应用了比特钳制,这使得一些BIP-32模式与Ed25519不兼容。因此,SLIP-0010规定禁止从现有用户的公钥中衍生出新的公钥。SLIP-0010只支持所谓的 "加固的 "私人父钥匙到私人子钥匙的衍生。

密钥派生路径

虽然BIP-32在层次结构中指定了钱包的级别,但BIP-44进一步定义了衍生路径的五个级别及其确切含义:M / purpose' / coin_type' / account' / change / address_index。在这个结构中,斜线表示层次结构中的新层次,或称子层。

目的层通常被设置为44,与BIP号码相对应。然而,在Sui中,目的层区分了不同的签名方案。44被设置为Ed25519,54被设置为ECDSA Secp256k1。虽然将目的级别设置为非44的值是不标准的,但使用目的字段来区分不同的签名方案是很常见的。例如,BIP-49和BIP-84被用来识别比特币的脚本类型。Sui选择54来表示ECDSA Secp256k1,因为54下没有现有的BIP,避免与任何比特币标准混淆。

coin_type 值是用所有其他加密货币的存储库来管理的。两个签名方案都使用Sui注册的coin_type,784。

详解Sui密码学中的钱包规范

账户级别通常用于在逻辑上分离用户账户和创建特定的账户类别。一些常见的使用情况包括:

  • 保管人管理多个用户账户。

  • 用户为特定目的指定账户,如捐款、储蓄和支出。

为了支持多账户,Sui建议从零开始递增账户级别。人们普遍认为,基于账户的货币只定义前三个层次,而基于UTXO的货币则增加了变化和地址层次的定义。因为Sui的面向对象的数据模型既不是UTXO也不是基于账户的(事实上它结合了两者),它采用了所有五个级别以获得最大的兼容性。

总结如下:

详解Sui密码学中的钱包规范

助记词支持

一旦Sui定义了从种子推导出主密钥的确定性方法,BIP-39就被引入,以使种子更容易被人阅读和记忆,使用记忆法。Sui接受来自BIP-39词表的12、15、18、21和24个词,这些词被适当地校验过,对应于128、160、192、224和256 bits的熵。

Sui的密钥管理

Sui通过其Typescript SDK和命令行界面(CLI)支持密钥对生成和相关的助记符。该SDK提供额外的功能,包括交易签名和RPC集成。

具体步骤如下:

  • 从助记符推导出一个密钥对

  • 获取其地址

  • 用它来签署一个序列化的类型化交易(或任何数据)

  • 针对RPC提供者执行

详解Sui密码学中的钱包规范

命令行界面

详解Sui密码学中的钱包规范

先进的钱包架构

钱包必须是安全的,但又便于其所有者访问。Sui依靠行业标准来指导对用户钱包的设计,同时在探索不同的签名方案时保持敏捷和灵活。除了Sui目前支持的钱包规格外,还在不断创新钱包设计,使与Sui的互动更安全,更容易使用。Sui将很快分享关于钱包预批准交易的设计。Sui钱包不需要一次一次地签署交易,而是让链上游戏变得实用,充分释放Sui网络上快速执行的潜力。

免责声明:本文章仅代表作者个人观点,不代表本平台的立场和观点。本文章仅供信息分享,不构成对任何人的任何投资建议。用户与作者之间的任何争议,与本平台无关。如网页中刊载的文章或图片涉及侵权,请提供相关的权利证明和身份证明发送邮件到support@aicoin.com,本平台相关工作人员将会进行核查。

Share