木星链 木星链
Ctrl+D收藏木星链

比特币:区块链基础知识篇——《精通比特币》第四章“密钥、地址、钱包”解读

作者:

时间:1900/1/1 0:00:00

通过本章的学习,可以帮你很具象的熟悉钱包的原理,以及私钥、公钥、比特币地址和钱包的关系。本章可以为产品和技术人员设计研发数字钱包时提供参考。

阅读时长:15分钟左右

4.1私钥、公钥、地址和钱包的关系

钱包:钱包是私钥的容器,钱包中只包含私钥,不包含比特币,钱包定义了一套生成私钥、管理私钥以及使用私钥签名的规则。

私钥:作用是对交易进行签名。由钱包通过随机熵源生成,也可由钱包导入已有的私钥。

公钥:由私钥通过特定的椭圆曲线函数生成。由私钥可以推出公钥,但由公钥很难计算出私钥。

比特币地址:由公钥经过单向的双哈希函数生成,通过Base58check编码的方式呈现,比特币地址以数字1开头。

在了解以上4个概念的关系后,下面详细讲解私钥、公钥、地址的生成原理以及钱包的分类。

4.2私钥的生成原理

私钥就是一个随机选出的数字而已,该随机数是一个二进制的256位数字。随机性数据来源于符合密码学安全的随机数生成器,即从一堆随机源的数据中取出一串随机字节,通过SHA算法转化成256位的二进制数字,再验证选择的随机数是否处于1到n-1之间(其中n是一个常数,略小于2^256),如果运算结果小于n-1,则随机数合适,否则需要重新选取随机数,直至所选取的随机数满足验证条件为止。

动态 | 广发银行正积极探索区块链技术在银行业务中的应用:据大众证券报12月8日消息,广发银行正积极探索区块链技术在银行业务中的应用,通过分布式账本、智能合约技术打破不同银行、不同行业间的业务与信息壁垒,实现数据资源共享,从而拓宽银行与各其他行业间的合作模式。目前广发银行已运用区块链技术实现集团内部的积分共享、转换、兑换,实现内部资源共享,提升集团客户体验。[2019/12/8]

当然,不同的钱包选取的随机数位数可能不一样。

私钥的表示方法

私钥的常见表示法有十六进制、WIF格式、WIF-compressed格式。

十六进制格式的私钥,是将原始256位的二进制数据转换成了64位的十六进制数据表示出来;

WIF,即钱包导入格式,指将私钥导入新的钱包中时,钱包用来识别私钥的格式,所以在钱包导出私钥时,会生成该格式的私钥。WIF格式的私钥以5开头,代表该格式的私钥需要生成非压缩格式的公钥。

WIF-compressed,即钱包导入压缩格式,该私钥的格式以K或L开头,将私钥导入到钱包后,代表钱包会用该格式的私钥生成压缩格式的公钥,以便正确解析比特币地址。

动态 | 数字创新机构研究报告:74%的英国区块链公司关注监管:据CCN报道,数字创新机构Digital Catapult进行的研究表明,74%的英国区块链公司将监管问题列为其关键问题之一,超越了技术,商业或法律专业知识等其它问题。这些监管挑战包括欧盟的通用数据保护条例(GDPR)。[2018/12/3]

4.3公钥的生成原理

私钥通过椭圆曲线函数,可以计算得到公钥,这是不可逆的过程:K=k*G。其中k是私钥,G是椭圆曲线上定义的初始常数点,K是公钥。

比特币的椭圆曲线方程:y^2=x^3+7,这条曲线定义在素数阶p的有限域内,可以想象为在一个极大的网格上定义了一系列复杂的散点。公钥K的计算运用了椭圆曲线的加法和乘法规则:k*G=G+G+……+G,且该椭圆曲线上的两个点想加,其相加的和等于与椭圆曲线相交于另一点、然后在X轴上的反射点。那么G+G的值相当于从G点做切线后与曲线相交点,其在X轴上的反射点2G,如下图所示:

图一椭圆曲线同点相加,图片来源于网络

公钥K定义为该反射点的坐标K=。

行情 | 在美上市区块链中概股涨多跌少:今日美股开盘,在美上市区块链中涨多跌少。人人网平盘,寺库上涨1.91%,中网载线上涨1.05%,迅雷上涨0.63%,猎豹移动上涨3.22%,兰亭集势下跌5.88%,优点互动平盘。[2018/11/14]

公钥的表示方法

公钥是根据椭圆曲线计算出来的坐标,知道了x的值,可以根据函数求出对应y的值。如果同时将x和y用256位二进制存储的话,所占空间将增大1倍,存储空间上有些浪费。所以,公钥的表示格式分为非压缩格式和压缩格式。

非压缩格式的公钥,是指生成的公钥拼接了x和y的值,非压缩格式的公钥,以前缀04开头。

压缩格式的公钥,是指生成的公钥中只包含了x的值,压缩格式的公钥,以前缀02或03开头。如上述椭圆曲线同点相加图示,同一个横坐标x可能对应2个y值,由于y在有限域中只有正数,此处的2个y值分别对应奇数和偶数,前缀02开头表示y是偶数,前缀03开头表示y是奇数。

由私钥生成压缩格式的公钥时,会在私钥的后面拼接01,用以表明该私钥来自于一个较新的钱包,只能用来生成压缩的公钥。对于私钥本身,是不会改变原值而压缩的。这样做的目的是为了给导入私钥的钱包一个信号:到底是使用压缩格式公钥和比特币地址去扫描区块链,还是使用非压缩格式公钥和比特币地址。

声音 | 伊朗央行首席执行官:伊朗欲开发国家区块链平台:8月27日消息,伊朗中央银行执行机构的首席执行官Aboutaleb Najafi表示:在银行、私营部门和所有其他利益相关者的帮助下,我们希望为银行创建一个区块链平台。他在一个关于区块链技术的会议上说,国家区块链将降低伊朗人民小额金融交易的成本,并将允许建立一个涉及伊朗及其盟友的转账网络。[2018/8/27]

4.4比特币地址

比特币地址是将公钥经过双哈希,得到公钥哈希后,采用Base58check编码的形式展示。比特币地址以1开头。

Base64编码是将任意的一长串输入转化成特定长度的数字和字母组成的表示法,其编码字符使用了26个小写字母、26个大写字母、10个数字和两个符号+以及/,Base58编码舍弃了一些容易错读和混淆的字符,其不含数字0,小写o、大写O、小写i、大写I以及+和/两个字符。Base58check编码采用的是Base58编码,同时加入了校验的功能。

最终的比特币地址由版本前缀、公钥哈希和校验码3部分组成。其中版本前缀用来标识编码后得到的是比特币地址,如采用Base58check编码时,比特币地址的前缀是0,私钥编码的前缀为128;公钥哈希,即将原始公钥经过SHA256和RIPEMD计算后得到的20字节的值;校验码,是由前缀拼接公钥哈希后,经过2次SHA256,取计算后的值的前4个字节得到。

恒天然携手阿里巴巴开启区块链技术试点:据中国网消息,恒天然旗下的安佳乳制品已成为阿里巴巴集团跨境食品溯源的互信框架合作试点第一批产品。该框架旨在通过区块链技术,提高供应链的可追溯性和透明度。恒天然大中华区总裁朱晓静表示,这一动向体现了恒天然持续以来对创建全球供应链可追溯性典范的承诺。作为一种新兴技术,区块链有潜力为经济带来改变,同时为我们的客户和消费者提供更大的价值。我们希望处于供应链开发食品质量和安全标准的最前沿。[2018/5/2]

比特币地址的生成原理,如下图所示:

图二比特币地址的生成原理

使用Base58check编码格式时,编码软件会计算原始数据的校验码和结果数据中自带的校验码进行对比,二者不匹配则表明有错误产生,那么这个地址也是无效的。

4.5比特币钱包的分类

钱包是用来管理私钥的容器。比特币钱包分为非确定性钱包钱包和确定性钱包。

非确定性钱包:由钱包预先随机生成N个私钥,每个私钥一旦使用,需要单独备份,当密钥足够多时,很难管理、备份和导入到新钱包,所以这种钱包使用起来很不方便,正被确定性钱包替代。

确定性钱包:又称种子钱包,顾名思义,即通过一个种子即可推出所有密钥。所以,在备份密钥或导入到新钱包时,只需要备份种子密钥即可,剩余的密钥可以根据既定规则推算出来。常见的确定性钱包,包含助记码词汇以及分层确定性钱包。

助记码词汇

助记码词汇是用英文单词序列代表作种子,来对应确定性钱包的随机数。单词的顺序就是钱包的备份,也就是对应的私钥集合。助记码词汇可以让使用者复制钱包更容易一些,它们相对于随机数字顺序来说,可以很容易的被读并且正确抄写。

助记码和种子的创建过程如下:

1.创造一个128到256位的随机顺序;

2.使用SHA256哈希该随机顺序,取前几位作为校验和。所选取的随机数的位数不同,校验和的字符数也不相同。

3.把校验和拼接在随机顺序的后面

4.按顺序把拼接后的值分解成11位不同的集合,并用这些集合去和一个预先已经定义的2048个单词字典做对应

5.取出对应的单词,按顺序即可生成一个12至24个词的助记码。

分层确定性钱包

分层确定性钱包,是通过单个种子生成主密钥,再由主密钥以树状结构衍生子密钥,子密钥又可以通过规则衍生出孙密钥,以此类推,一个种子可以衍生出无穷个子密钥,而且备份时只需备份种子即可将钱包中的所有密钥备份。

由种子衍生主密钥的过程:

如上图所示,由随机数生成种子后,通过单向哈希函数,输出512位的值,其中左边的256位做为主密钥,右边的256位作为主链编码。

由父私钥衍生子私钥的过程:

如上图所示,父私钥衍生子私钥时,先由父私钥生成父公钥,再由父公钥、父链编码和索引号通过单向哈希函数计算输出512位的值,左边的256位对应子密钥,右边的256位对应子链编码。其中索引号用来标识子私钥对应的位置。

4.6总结

通过本章的学习,可以很具象的熟悉私钥、公钥和比特币地址的背后原理,同时了解钱包的本质及其管理私钥的方式。本章可以为产品和技术人员设计研发数字钱包时提供参考。

推荐阅读

区块链基础知识篇——《精通比特币》第三章“比特币客户端”解读

区块链基础知识篇——《精通比特币》第二章“比特币的原理”解读

区块链基础知识篇——比特币经典书籍《精通比特币》第一章解读

比特币是有钱人的收藏品,不具备社会流通价值

作为一个普通白领,我为什么会认可区块链?

区块链大火,这是普通人参与区块链投资最简单直接的方式

Tina说

转型区块链,来这里就对了

标签:比特币区块链SHA比特币中国官网联系方式40亿比特币能提现吗比特币最新价格行情走势区块链工程专业学什么区块链存证怎么弄区块链技术发展现状和趋势SHA价格SHA币

火币APP下载热门资讯
SOL:汉腾首台MPV上市,起售价6.59万元?这台德国车可就豪华了

汉腾汽车,现在在很多消费者的耳边才开始有了回绕,之前在中国市场上知名度并不高,并且如今在车型中阵营也是薄弱的,仅两台SUV、而也是靠两台SUV汉腾X5与汉腾X7打出了自己的名号.

1900/1/1 0:00:00
区块链:首次达成无核化协议,朝韩决定自己掌握半岛命运

9月19日,在朝鲜平壤,韩朝领导人共同会见记者。9月19日,朝鲜最高领导人金正恩和韩国总统文在寅举行第三次会晤的第二轮首脑会谈。会谈结束后,双方签署《9月平壤共同宣言》.

1900/1/1 0:00:00
比特币:礼仪 | 万圣节……中元节……“为什么说鬼会返回人间?”

比如说: 去一场说走就走的远行; 比如说赶紧跳槽做一份自己真正喜爱的工作;比特币矿商Sazmining在南美洲巴拉圭设立新工厂:金色财经报道.

1900/1/1 0:00:00
BCH:比特大陆All in 比特币现金,吴忌寒能再续矿霸传奇?

作者/坎村设计/大脚排版/TOM一个月前,BCH社区成员在香港庆祝BCH诞生一周年。当时,比特大陆创始人吴忌寒、Bitcoin.com所有者RogerVer、BTC.top创始人江卓尔、nCha.

1900/1/1 0:00:00
区块链:QUTM量子链是什么

英文名:Qtum/QTUM 中文名:量子链 所属国家:中国 发行时间:2017-03-16 发行总量:1.08亿 项目概念:公链代币 切入点: 1.

1900/1/1 0:00:00
XRP:「9.25行情分析」比特币向下突破,短期风险升级

一、市场行情回顾 全球数字资产从昨日下午开始小幅下跌,而后在今日早间开始快速下跌,最终稳定在2100亿美元附近.

1900/1/1 0:00:00