比特币:数字钱包概念

钱包用来存钱的,在区块链中,我们的数字资产都会对应到一个账户地址上,只有拥有账户的钥匙才可以对资产进行消费。

私钥和地址的关系如下:

图来自精通比特币)一句话概括下就是:私钥通过椭圆曲线生成公钥,公钥通过哈希函数生成地址,这两个过程都是单向的。

因此实际上,数字钱包实际是一个管理私钥的工具,注意钱包并不保存资产,资产是在链上的。

如何创建账号

数字钱包 Cenoa 完成 700 万美元种子轮融资:2 月 6 日消息,基于区块链的非托管数字钱包 Cenoa 完成 700 万美元融资,Quite Capital 和 Underscore 领投,Human Capital、Ulu Ventures、Acrew Capital 和 Collective Spark 等参投。

据悉,Cenoa 本轮融资将用于拓展拉丁美洲、非洲、东南亚和欧洲市场以及招聘。Cenoa 旨在为新兴市场用户提供接触美元产品的渠道,并称基于区块链技术,其非托管储蓄解决方案降低了分支机构的成本、中介费用并减少传统银行业务的其他低效程序。[2023/2/6 11:50:33]

创建账号关键是生成一个私钥,私钥是一个32个字节的数,生成一个私钥在本质上在1到2^256之间选一个数字。因此生成密钥的第一步也是最重要的一步,是要找到足够安全的熵源,即随机性来源,只要选取的结果是不可预测或不可重复的,那么选取数字的具体方法并不重要。

PayPal CEO:需要在数字钱包上加倍投入,相信这就是行业的未来:金色财经报道,PayPal 总裁兼首席执行官 Dan Schulman周三在公司季度财报电话会议上强调,数字钱包将在这家数字支付公司的未来增长中发挥关键作用。?Dan Schulman表示,

我们需要在数字钱包上加倍投入,我们相信这就是行业的未来,这是 PayPal 的未来,它是我们的核心。Schulman引用了几个统计数据作为理由:超过 50% 的 PayPal 用户使用公司的数字钱包,使用数字钱包的客户在结账时的交易量比不使用的用户多 25%,超过 70% 的“现在购买”后付款(?BNPL?) 用户是通过该公司的数字钱包完成的。

此外,根据Schulman的说法,数字钱包的流失率,或客户停止使用特定服务的比率,比 PayPal 的其他客户群低 25%。?(The block)[2022/4/28 2:35:58]

比如可以掷硬币256次,用纸和笔记录正反面并转换为0和1,随机得到的256位二进制数字可作为钱包的私钥。

数字钱包与比特币托管机构Xapo不再支持通过信用卡向账户输入资金:数字钱包与比特币托管机构Xapo在6月11日表示,从11日起用户将不再能通过信用卡向账户输入资金。除此之外,银行转账需要满足最小交易额与用户所在地点的限制。(Coindesk)[2020/6/12]

从编程的角度来看,一般是通过在一个密码学安全的随机源(不建议大家自己去写一个随机数)中取出一长串随机字节,对其使用SHA256哈希算法进行运算,这样就可以方便地产生一个256位的数字。

实际过程需要比较下是否小于n-1,我们就有了一个合适的私钥。否则,我们就用另一个随机数再重复一次。这样得到的私钥就可以根据上面的方法进一步生成公钥及地址。

BIP32

钱包也是一个私钥的容器,按照上面的方法,我们可以生成一堆私钥,而每个私钥都需要备份就特别麻烦的。

最早期的比特币钱包就是就是这样,还有一个昵称:“JustaBunchOfKeys(一堆私钥)“

为了解决这种麻烦,就有了BIP32提议:根据一个随机数种子通过分层确定性推导的方式得到n个私钥,这样保存的时候,只需要保存一个种子就可以,私钥可以推导出来,如图:

上图中的孙秘钥就可以用来签发交易。

补充说明下BIP:BitcoinImprovementProposals比特币改进建议,bip32是第32个改进建议。BIP32提案的名字是:HierarchicalDeterministicWallets,就是我们所说的HD钱包。

来分析下这个分层推导的过程,第一步推导主秘钥的过程:

根种子输入到HMAC-SHA512算法中就可以得到一个可用来创造主私钥(m)和一个主链编码及主链编码再加上一个索引号,将作为HMAC-SHA512算法的输入继续衍生出下一层的私钥及链编码,如下图:

衍生推导的方案其实有两个:一个用父私钥推导,一个用父公钥推导。同时为了区分这两种不同的衍生,在索引号也进行了区分,索引号小于2^31用于常规衍生,而2^31到2^32-1之间用于强化衍生,为了方便表示索引号i',表示2^31+i。

因此增加索引及通过子秘钥向下一层可以无限生成私钥。

注意,这个推导过程是确定也是单向的,子密钥不能推导出同层级的兄弟密钥,也不能推出父密钥。如果没有子链码也不能推导出孙密钥。现在我们已经对分层推导有了认识。

一句话概括下BIP32就是:为了避免管理一堆私钥的麻烦提出的分层推导方案。

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

金星链

[0:0ms0-0:506ms