比特币基础知识书比特币基础知识书籍

各位老铁们好,相信很多人对比特币基础知识书都不是特别的了解,因此呢,今天就来为大家分享下关于比特币基础知识书以及比特币基础知识书籍的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

本文目录

区块链入门看什么书比特币基础知识 你绝对想不到比特币如何算出来的区块链有哪些入门书籍区块链入门看什么书《大话区块链》是2019年9月清华大学出版社出版的图书,作者是张应平。本书是一本全面讲解比特币、以太坊、超级账本、EOS的区块链书籍,一本从工程师基本功、开发语言到智能合约开发的区块链开发指南,一本从技术、项目到职业发展规划的区块链工程师指导手册。

《大话区块链》

《大话区块链》是一本理论与实战并重、通俗易懂又不失专业的区块链书籍。区块链技术指南部分(前三章)主要讲解了区块链概念、区块链应用和比特币、以太坊、超级账本、EOS等主流区块链技术,通过学习每个读者都可以全面理解主流区块链技术实现原理,了解区块链未来发展趋势。开发实战部分(后两章)从区块链基本技能开始,模拟真实区块链项目开发,详细讲解了智能合约和DAPP的设计、开发以及部署,通过学习每个读者都可以掌握区块链开发。

比特币基础知识 你绝对想不到椭圆曲线数字签名算法

椭圆曲线数字签名算法(ECDSA)是使用椭圆曲线对数字签名算法(DSA)的模拟,该算法是构成比特币系统的基石。

私钥

非公开,拥有者需安全保管。通常是由随机算法生成的,说白了,就是一个巨大的随机整数,32字节,256位。

大小介于1~0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141之间的数,都可以认为是一个合法的私钥。

于是,除了随机方法外,采用特定算法由固定的输入,得到32字节输出的算法就可以成为得到私钥的方法。于是,便有了迷你私钥(MiniPrivkey),原理很简单,例如,采用SHA256的一种实现:

privatekey=SHA256()1

迷你私钥存在安全问题,因为输入集合太小,易被构造常见组合的彩虹表暴力破解,所以通常还是使用系统随机生成的比较好,无安全隐患。

公钥

公钥与私钥是相对应的,一把私钥可以推出唯一的公钥,但公钥却无法推导出私钥。公钥有两种形式:压缩与非压缩。

早期比特币均使用非压缩公钥,现大部分客户端已默认使用压缩公钥。

这个貌似是比特币系统一个长得像feature的bug,早期人少活多代码写得不够精细,openssl库的文档又不足够好,导致Satoshi以为必须使用非压缩的完整公钥,后来大家发现其实公钥的左右两个32字节是有关联的,左侧(X)可以推出右侧(Y)的平方值,有左侧(X)就可以了。

现在系统里两种方式共存,应该会一直共存下去。两种公钥的首个字节为标识位,压缩为33字节,非压缩为65字节。以0x04开头为非压缩,0x02/0x03开头为压缩公钥,0x02/0x03的选取由右侧Y开方后的奇偶决定。

压缩形式可以减小Tx/Block的体积,每个TxInput减少32字节。

签名

使用私钥对数据进行签署(Sign)会得到签名(Signature)。通常会将数据先生成Hash值,然后对此Hash值进行签名。签名(signature)有两部分组成:R+S。由签名(signature)与Hash值,便可以推出一个公钥,验证此公钥,便可知道此签名是否由公钥对应的私钥签名。

通常,每个签名会有三个长度:73、72、71,符合校验的概率为25%、50%、25%。所以每次签署后,需要找出符合校验的签名长度,再提供给验证方。

地址

地址是为了人们交换方便而弄出来的一个方案,因为公钥太长了(130字符串或66字符串)。地址长度为25字节,转为base58编码后,为34或35个字符。base58是类似base64的编码,但去掉了易引起视觉混淆的字符,又在地址末尾添加了4个字节校验位,保障在人们交换个别字符错误时,也能够因地址校验失败而制止了误操作。

由于存在公钥有两种形式,那么一个公钥便对应两个地址。这两个地址都可由同一私钥签署交易。

公钥生成地址的算法:

Version=1byteof0(zero);onthetestnetwork,thisis1byteof111

Keyhash=VersionconcatenatedwithRIPEMD-160(SHA-256(publickey))

Checksum=1st4bytesofSHA-256(SHA-256(Keyhash))

BitcoinAddress=Base58Encode(KeyhashconcatenatedwithChecksum)1234

下图是非压缩公钥生成地址的过程:

对于压缩公钥生成地址时,则只取公钥的X部分即可。

推导关系

三者推导关系:私钥

公钥

两个地址。过程均不可逆。拥有私钥便拥有一切,但通常为了方便,会把对应的公钥、地址也存储起来。

交易

比特币的交易(Transation,缩写Tx),并不是通常意义的交易,例如一手交钱一手交货,而是转账。交易由N个输入和M个输出两部分组成。交易的每个输入便是前向交易的某个输出,那么追踪到源头,必然出现一个没有输入的交易,此类交易称为CoinBaseTx。CoinBase类交易是奖励挖矿者而产生的交易,该交易总是位于Block块的第一笔。

拥有一个输入与输出的Tx数据:

Input:

Previoustx:f5d8ee39a430901c91a5917b9f2dc19d6d1a0e9cea205b009ca73dd04470b9a6

Index:0

scriptSig:304502206e21798a42fae0e854281abd38bacd1aeed3ee3738d9e1446618c4571d10

90db022100e2ac980643b0b82c0e88ffdfec6b64e3e6ba35e7ba5fdd7d5d6cc8d25c6b241501

Output:

Value:5000000000

scriptPubKey:OP_DUPOP_HASH160404371705fa9bd789a2fcd52d2c580b65d35549d

OP_EQUALVERIFYOP_CHECKSIG12345678910

一旦某个Tx的第N个输出成为另一个Tx的输入,那么该笔比特币即为已花费。每个交易有唯一Hash字符串来标识,通过对交易数据做两次SHA256哈希运算而来:

TxHashID=SHA256(SHA256(TxData))1

矿工费

矿工费(TransactionFee)是鼓励矿工将Tx打包进Block的激励报酬。计算一笔交易的矿工费:

TransactionFee=SUM(Inputsamount)-SUM(Outputsamount)1

每笔Tx的矿工费必然大于等于零,否则该笔Tx即为非法,不会被网络接收。

数据块

数据块(Block)是存储BlockMeta与Tx的地方。Block的第一笔Tx总是CoinBaseTx,因此Block中的交易数量总是大于等于1,随后是这段时间内网络广播出来的Tx。

找到合适的Block是一件非常困难的事情,需要通过大量的数学计算才能发现,该计算过程称为“挖矿”。首个发现者,会得到一些比特币作为奖励。

数据链

多个Block连接起来成为数据链(BlockChain)。

为了引入容错与竞争机制,比特币系统允许BlockChain出现分叉,但每个节点总是倾向于选择最高的、难度最大的链,并称之为BestChain,节点只认可BestChain上的数据。

首个Block称为GenesisBlock,并设定高度为零,后续每新增一个Block,高度则递增一。目前是不允许花费GenesisBlock中的比特币的。

每个Block中的Tx在此Block中均唯一

一个Tx通常只会在一个Block里,也可能会出现在多个Block中,但只会在BestChain中的某一个Block出现一次

货币存储

比特币是密码货币、纯数字化货币,没有看得见摸得着的硬币或纸币。一个人持有比特币意味着:

其拥有一些地址的私钥

这些地址是数笔交易的输出,且未花费

所有货币记录均以交易形式存储在整个blockchain数据块中,无交易无货币。货币不会凭空产生,也不会凭空消失。遗失了某个地址的私钥,意味着该地址上的Tx无法签署,无法成为下一个Tx的输入,便认为该笔比特币永久消失了。

货币发行

既然所有交易的输入源头都是来自CoinBase,产生CoinBase时即意味着货币发行。比特币采用衰减发行,每四年产量减半,第一个四年每个block的coinbase奖励50BTC,随后是25btc,12.5btc,并最终于2140年为零,此时总量达到极限为2100万个btc。

减半周期,严格来说,并不是准确的四年,而是每生成210000个block。之所以俗称四年减半,是因为比特币系统会根据全网算力的大小自动调整难度系统,使得大约每两周产生2016个block,那么四年约21万块block。

该函数GetBlockValue()用于计算挖得Block的奖励值:

int64staticGetBlockValue(intnHeight,int64nFees)

{

int64nSubsidy=50*COIN;

//Subsidyiscutinhalfevery210000blocks,whichwilloccurapproximatelyevery4years

nSubsidy=(nHeight/210000);

returnnSubsidy+nFees;

}123456789

当达到2100万btc以后,不再有来自CoinBase的奖励了,矿工的收入来源仅剩下交易的矿工费。此时,每个block的收入绝对值btc很低,但此时比特币应当会非常繁荣,币值也会相当的高,使得矿工们依然有利可图。

杜绝多重支付

传统货币存在多重支付(DoubleSpending)问题,典型的比如非数字时代的支票诈骗、数字时代的信用卡诈骗等。在比特币系统里,每笔交易的确认均需要得到全网广播,并收录进Block后才能得到真正确认。每笔钱的花销,均需要检测上次输入交易的状态。数据是带时间戳的、公开的,BlockChain由巨大的算力保障其安全性。所以比特币系统将货币的多重支付的风险极大降低,几近于零。通过等待多个Block确认,更是从概率上降低至零。一般得到6个确认后,可认为非常安全。但对于能影响你人生的重大支付,建议等待20~30个确认。

匿名性

任何人均可以轻易生成大量的私钥、公钥、地址。地址本身是匿名的,通过多个地址交易可进一步提高匿名性。但该匿名性并不像媒体宣传的那样,是某种程度上的匿名。因为比特币的交易数据是公开的,所以任何一笔资金的流向均是可以追踪的。

不了解比特币的人为它的匿名性产生一些担忧,比如担心更利于从事非法业务;了解比特币的人却因为它的伪匿名性而苦恼。传统货币在消费中也是匿名的,且是法律保障的,大部分国家都不允许个人涂画纸币。

地址本身是匿名的,但你可以通过地址对应的私钥签名消息来向公众证明你拥有某个比特币地址。

其他名词

哈希

哈希(Hash)是一种函数,将一个数映射到另一个集合当中。不同的哈希函数映射的空间不同,反映到计算机上就是生成的值长度不一样。同一个哈希函数,相同的输入必然是相同的输出,但同一个输出却可能有不同的输入,这种情况称为哈希碰撞。

常见的哈希函数有CRC32,MD5,SHA1,SHA-256,SHA-512,RIPEMD-160等,哈希函数在计算中有着非常广泛的用途。比特币里主要采用的是SHA-256和RIPEMD-160。

脑钱包纸钱包

前面提到过的脑钱包与纸钱包,这其实不算是钱包的分类,只是生成、存储密钥的方式而已。脑钱包属于迷你私钥的产物。脑钱包就是记在脑袋里的密钥,纸钱包就是打印到纸上的密钥,仅此而已。

有同学提到过,以一个计算机文件作为输入,例如一个数MB大小的照片,通过某种Hash运算后得到私钥的方法。这个方案的安全性还是不错的,同时可以防止盗私钥木马根据特征扫描私钥。文本形式存储私钥是有特征的,而一个照片文件却难以察觉,即使放在云盘等第三方存储空间中都是安全的。

比特币如何算出来的从比特币的本质说起,比特币的本质其实就是一堆复杂算法所生成的特解。特解是指方程组所能得到有限个解中的一组。而每一个特解都能解开方程并且是唯一的。

以钞票来比喻的话,比特币就是钞票的冠字号码,知道了某张钞票上的冠字号码,就拥有了这张钞票。而挖矿的过程就是通过庞大的计算量不断的去寻求这个方程组的特解,这个方程组被设计成了只有2100万个特解,所以比特币的上限就是2100万个。

要挖掘比特币可以下载专用的比特币运算工具,然后注册各种合作网站,把注册来的用户名和密码填入计算程序中,再点击运算就正式开始。完成Bitcoin客户端安装后,可以直接获得一个Bitcoin地址,当别人付钱的时候,只需要自己把地址贴给别人,就能通过同样的客户端进行付款。

在安装好比特币客户端后,它将会分配一个私钥和一个公钥。需要备份你包含私钥的钱包数据,才能保证财产不丢失。如果不幸完全格式化硬盘,个人的比特币将会完全丢失。

钱包

比特币钱包使用户可以检查、存储、花费其持有的比特币,其形式多种多样,功能可繁可简,它可以是遵守比特币协议运行的各种工具,如电脑客户端、手机客户端、网站服务、专用设备;

也可以只是存储著比特币私密密钥的介质,如一张纸、一段暗号、一个快闪U盘、一个文本文档,因为只要掌握比特币的私密密钥,就可以处置其对应地址中包含的比特币。比特币无法存入一般的银行账户,交易只能在比特币网络上进行,使用前需下载客户端或接入线上网络。

以上内容参考百度百科-比特币

区块链有哪些入门书籍<入门认知篇>

《新经济蓝图及导读》

出版年份:2016年

推荐语:这本书侧重写了区块链前景的展望,书中除了作者原书的翻译,还增加了一些导读部分,案例丰富全面,讲解详细又不失理论高度,如果对区块链、互联网金融感兴趣,千万不要错过。维优元界(http://mvs.org)的CEO初夏虎(Eric)也参与了本书的翻译。

《区块链:从数字货币到信用社会》

出版年份:2016年

推荐语:本书系统地对区块链的历史和现状、起源与发展以及问题和未来发展方向进行了总结梳理,结合进阶区块链、如何应用区块链、政府监管等进行案例分析,系统而又浅显。

《区块链:重塑经济与世界》

出版时间:2016年

推荐语:区块链的入门科普书籍,从区块链源头到未来,从目前的应用进展到未来应用蓝图,作者为业界一线成员和专家学者,汇聚实战和理论,具有很大的参考性。

<投资篇>

《如何投资数字货币》

出版时间:2017年

推荐语:开篇以基础知识作为铺垫,接着第二部分介绍了投资交易方法,第三部分是投资理念,最后结合比特时代,狗狗币等案例介绍了区块链的发展和应用。可以让投资者通过本书快速的了解数字货币投资。

《虚拟货币投资实战技巧》

出版年份:2017年

推荐语:致力于把各种价格分析技术和传统市场的操作理论用于虚拟货币市场,结合K线进行技术分析。技术党和短线爱好者不可放过的经典书籍。

《区块链社会解码区块链全球应用与投资案例》

出版时间:2016年

推荐语:介绍了区块链这一新兴技术在全球各行业的各种应用,并介绍了区块链技术的基本原理,共识机制以及发展脉络,独家披露了全球258个区块链行业内投资案例的详细数据。在投资上具有较强的价值参考。

<技术篇>

《精通比特币》

出版时间:2015年

推荐语:从比特币原理到钱包挖矿再到竞争币等涉及的名词,针对于不同的用户群体从多个角度来阐释各关键技术概念。围绕比特币进行区块链科普。

《区块链技术指南》

出版时间:2016年

推荐语:从技术视角适来揭秘区块链,从入门基础知识到技术构建,帮助初学者入门,在最后回顾了区块链和IT之间的发展和未来的展望。

《C#区块链编程》

出版时间:2016年

推荐语:本书主要面向程序员。结合API编程告诉你加密货币的原理、使用方法,以及如何开发与之相关的软件,对于非程序员读者们,本书前几章作为对比特币的深入介绍依然适用。(书籍pdf下载:https://quant.la/Download)

好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!

区块链

理财天下

货币行情

上一篇: 比特币地址转换比特币地址转账
下一篇: 比特币基础知识比特币基础知识书
相关推荐

猜你喜欢