通过本章的学习,可以帮你很具象的熟悉钱包的原理,以及私钥、公钥、比特币地址和钱包的关系。本章可以为产品和技术人员设计研发数字钱包时提供参考。
阅读时长:15分钟左右
4.1私钥、公钥、地址和钱包的关系
钱包:钱包是私钥的容器,钱包中只包含私钥,不包含比特币,钱包定义了一套生成私钥、管理私钥以及使用私钥签名的规则。
私钥:作用是对交易进行签名。由钱包通过随机熵源生成,也可由钱包导入已有的私钥。
公钥:由私钥通过特定的椭圆曲线函数生成。由私钥可以推出公钥,但由公钥很难计算出私钥。
比特币地址:由公钥经过单向的双哈希函数生成,通过Base58check编码的方式呈现,比特币地址以数字1开头。
在了解以上4个概念的关系后,下面详细讲解私钥、公钥、地址的生成原理以及钱包的分类。
4.2私钥的生成原理
私钥就是一个随机选出的数字而已,该随机数是一个二进制的256位数字。随机性数据来源于符合密码学安全的随机数生成器,即从一堆随机源的数据中取出一串随机字节,通过SHA算法转化成256位的二进制数字,再验证选择的随机数是否处于1到n-1之间(其中n是一个常数,略小于2^256),如果运算结果小于n-1,则随机数合适,否则需要重新选取随机数,直至所选取的随机数满足验证条件为止。
瑞银CEO:认为未来将朝着区块链的方向发展:金色财经报道,瑞银CEO Ermotti:认为未来将朝着区块链的方向发展。瑞银集团正在利用人工智能提升客户服务质量。[2023/6/27 22:02:58]
当然,不同的钱包选取的随机数位数可能不一样。
私钥的表示方法
私钥的常见表示法有十六进制、WIF格式、WIF-compressed格式。
十六进制格式的私钥,是将原始256位的二进制数据转换成了64位的十六进制数据表示出来;
WIF,即钱包导入格式,指将私钥导入新的钱包中时,钱包用来识别私钥的格式,所以在钱包导出私钥时,会生成该格式的私钥。WIF格式的私钥以5开头,代表该格式的私钥需要生成非压缩格式的公钥。
WIF-compressed,即钱包导入压缩格式,该私钥的格式以K或L开头,将私钥导入到钱包后,代表钱包会用该格式的私钥生成压缩格式的公钥,以便正确解析比特币地址。
4.3公钥的生成原理
私钥通过椭圆曲线函数,可以计算得到公钥,这是不可逆的过程:K=k*G。其中k是私钥,G是椭圆曲线上定义的初始常数点,K是公钥。
昆明市区块链赋能平台进入试运行阶段:昨日,昆明市区块链赋能平台正式发布,并进入试运行阶段。昆明市区块链赋能平台是中国移动云南公司昆明分公司投建的区块链即服务(BAAS)平台。平台提供区块链底层技术支撑,为项目方搭建灵活、可控、公信力强的低成本区块链网络。据介绍,昆明市区块链赋能平台提供公网产品和专网产品,分别服务于互联网和政务专网。(昆明日报)[2021/4/21 20:41:56]
比特币的椭圆曲线方程:y^2=x^3+7,这条曲线定义在素数阶p的有限域内,可以想象为在一个极大的网格上定义了一系列复杂的散点。公钥K的计算运用了椭圆曲线的加法和乘法规则:k*G=G+G+……+G,且该椭圆曲线上的两个点想加,其相加的和等于与椭圆曲线相交于另一点、然后在X轴上的反射点。那么G+G的值相当于从G点做切线后与曲线相交点,其在X轴上的反射点2G,如下图所示:
图一椭圆曲线同点相加,图片来源于网络
公钥K定义为该反射点的坐标K=。
公钥的表示方法
公钥是根据椭圆曲线计算出来的坐标,知道了x的值,可以根据函数求出对应y的值。如果同时将x和y用256位二进制存储的话,所占空间将增大1倍,存储空间上有些浪费。所以,公钥的表示格式分为非压缩格式和压缩格式。
声音 | 邓建鹏:区块链监管立法,不妨“以链治链”:11月1日,中央财经大学法学院教授、博士生导师邓建鹏在新京报刊文《区块链监管立法,不妨“以链治链”》。文章表示,金融领域是区块链应用的一个重要区域。当前,虚拟货币的法律定位模糊,负面影响了监管政策。政府将区块链技术作为监管技术,对监管机构及整个社会都有好处──降低合规和执法成本,法律自动执行,减少法律文本固有的不确定性。如果这些系统获得主流应用和政府支持,将促成建立一个新的监管框架。在简单的禁令式监管之外,这一思路为中国提供了极为有益的启示。政府在把握鼓励金融科技创新与风险控制平衡点的前提下,监管思维应及时跟进,推动区块链技术与监管技术的融合。从维护国家金融安全与风险防范长效监管机制和国际经验考虑,中国应尽快推动区块链领域的谨慎监管。[2019/11/1]
非压缩格式的公钥,是指生成的公钥拼接了x和y的值,非压缩格式的公钥,以前缀04开头。
压缩格式的公钥,是指生成的公钥中只包含了x的值,压缩格式的公钥,以前缀02或03开头。如上述椭圆曲线同点相加图示,同一个横坐标x可能对应2个y值,由于y在有限域中只有正数,此处的2个y值分别对应奇数和偶数,前缀02开头表示y是偶数,前缀03开头表示y是奇数。
动态 | 瑞士最大零售商采用基于区块链技术的溯源系统:瑞士最大的零售商Migros采用基于区块链技术的溯源系统,对其供应链内的新鲜水果和蔬菜进行溯源追踪。(prweb)[2019/8/29]
由私钥生成压缩格式的公钥时,会在私钥的后面拼接01,用以表明该私钥来自于一个较新的钱包,只能用来生成压缩的公钥。对于私钥本身,是不会改变原值而压缩的。这样做的目的是为了给导入私钥的钱包一个信号:到底是使用压缩格式公钥和比特币地址去扫描区块链,还是使用非压缩格式公钥和比特币地址。
4.4比特币地址
比特币地址是将公钥经过双哈希,得到公钥哈希后,采用Base58check编码的形式展示。比特币地址以1开头。
Base64编码是将任意的一长串输入转化成特定长度的数字和字母组成的表示法,其编码字符使用了26个小写字母、26个大写字母、10个数字和两个符号+以及/,Base58编码舍弃了一些容易错读和混淆的字符,其不含数字0,小写o、大写O、小写i、大写I以及+和/两个字符。Base58check编码采用的是Base58编码,同时加入了校验的功能。
动态 | 面向智慧城市数据可信交换的区块链产品“城市链”在物博会首发:据新华网消息,2018世界物联网博览会期间,26份研究报告和61项新技术新产品新应用成果集中展现。Gartner《物联网助推数字经济新发展——世界物联网发展蓝皮书》、中国经济信息社《2017-2018中国物联网发展年度报告》以及全球首个面向未来智慧城市的数据可信交换的区块链产品——“城市链”的概念和企划在物博会上首发,《工业物联网白皮书(互联互通篇)》《医疗健康物联网白皮书(2018)》等重量级报告发布。[2018/9/19]
最终的比特币地址由版本前缀、公钥哈希和校验码3部分组成。其中版本前缀用来标识编码后得到的是比特币地址,如采用Base58check编码时,比特币地址的前缀是0,私钥编码的前缀为128;公钥哈希,即将原始公钥经过SHA256和RIPEMD计算后得到的20字节的值;校验码,是由前缀拼接公钥哈希后,经过2次SHA256,取计算后的值的前4个字节得到。
比特币地址的生成原理,如下图所示:
图二比特币地址的生成原理
使用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币
中新经纬客户端9月11日电路透社10日消息称,美国纽约州金融服务部(NYDFS)近日批准了数字资产交易所GeminiTrust和区块链公司PaxosTrust各发行一种与美元挂钩的数字货币稳定币.
1900/1/1 0:00:00宏观新闻 1、网友统计项目方ICO钱包情况Augur项目几乎全部提现近日微博网友统计了一份各项目方ICO钱包的提现情况,此次统计共涉及58个项目.
1900/1/1 0:00:00一部最新的健康纪录片,悄悄火爆了朋友圈。据说传播它的,都是25-35岁的很多年轻上班族。没办法,和美丽、健康有关啊。中国人的传统“进补”观,比如吃些人参虫草鳖精啊,那都是长辈的信仰.
1900/1/1 0:00:00据相关媒体显示,coinbase又出一项新专利,将进一步提高了比特币交易的安全系数。在8月14日公布的文件中,这家加密货币交易所介绍了一个它新开发的支付门户网站,允许用户直接使用电子钱包中的比特.
1900/1/1 0:00:00根据美通社报道,纽约时间2018年6月19日,Coinmint和Innosilicon宣布双方达成全面战略合作.
1900/1/1 0:00:00大家好,今天又是阳光明媚的一天,我是人见人爱,花见花开,车见车爆胎的帅气小编,今天又给大家带来了不一样的精彩内容,大家看了之后如果觉得有兴趣记得多多关注小编哦,据说关注了小编,桃花运漫天飞.
1900/1/1 0:00:00