大家好,这里是了链客区块链技术问答社区。
链客,专为开发者而生,有问必答!
去中心化说起来似乎挺简单,但是不用细想就会发现很多问题:
账本存储在每个节点中,如何保证每个节点中的数据一致,或者说如何防止某些节点的账本被恶意篡改而影响到整个网络的交易?
如果说交易的验证由各个节点完成,那么如何在不把密码泄露给其他节点的前提下,证明自己对某个账户的所有权呢?
去中心化就要求时刻有节点在线,由这些节点去完成记账、验证交易等工作,那么有什么机制能够让节点有动力自发的保持在线去完成这些工作呢?
美国职棒大联盟球队总裁:若获得比特币支付将坚持持有:3月29日消息,美国职棒大联盟球队Oakland Athletics总裁Dave Kaval近期被问及为何接受比特币预定赛季套房时表示,因为球迷在6到8个月之前就一直在询问是否接受加密支付。Kaval称为此特意预留了十间房,但目前还未收到预定。Kaval还称:“我们目前只关注比特币,但如有需要也会支持其他加密货币。我们利用bitPay处理后端,可以接受其他形式的加密货币。所以我们对此持开放态度。”此外,Kaval还表示,如果获得了比特币支付便会一直持有,而不会兑现。
此前消息,美国职棒大联盟球队Oakland Athletics宣布,球迷们现在可用1枚比特币购买2021年赛季的一套6人住宿套房。套房定价为6.48万美元,球迷可在4月1日前选择是否接受该提议。该球队总裁Dave Kaval表示,并不担心价格波动。(CryptoGlobe)[2021/3/29 19:26:32]
对于上面的问题,比特币都给出了很优雅的解决方案,我们一一道来。
加密分析师:比特币不太可能受到美国总统选举的影响:加密分析师Nicholas Merten认为,比特币(BTC)不太可能受到美国总统选举的影响,尽管他说股票市场可能会崩溃。他指出,比特币在选举之夜的价格走势与前几天和前几周一样。他称,“这也符合我们的理论,即比特币不会受到任何影响。对于作为一种资产类别的加密货币来说,没有哪个候选人能真正提供戏剧性的好处或坏处。”(The Daily HODL)[2020/11/5 11:45:03]
1.账本验证问题
实际上对于第一个问题,很容易想到解决方法,那就是少数服从多数,如果某个节点的账本数据被篡改了,那么只需要和全网其他节点的数据比对,就必然能发现异常。
某YouTube频道冒充比尔·盖茨和微软进行比特币:上周日,网络窃贼在YouTube的“微软欧洲”的频道上发布了一个伪造的“加密货币赠品”直播,并放出对比尔·盖茨的旧采访。视频左侧的文本声称该科技巨头正在发放比特币,但是??为了获得免费的加密货币,参与者必须首先将自己的比特币发送到特定地址,者答应寄回0.2到40 BTC作为奖励。该频道的订阅人数超过30,000,直播过程中观看人数一度超过这一数字。(Dailyhodl)[2020/3/30]
但问题在于,随着时间的推移,记录的累积,数据量会越来越庞大,记得在13年的时候,笔者下载的比特币钱包,从网络同步下载下来的交易账本数据就已经多达几十GB,如果说要对这么大的数据进行逐一传输、比对,可以说是不现实的。
在介绍比特币的解决方案前,我们先了解一个函数:Hash函数,俗称哈希函数。
道富董事总经理:比特币还没有真正像电子交易一样占领市场:3月2日消息,道富(State Street)数字产品开发创新董事总经理Jay Biancamano表示,区块链技术和数字资产将影响市场的许多不同角落,就像几十年前电子交易影响市场一样。他还指出,比特币还没有像电子交易那样占领市场。(AMBcrypto )[2020/3/2]
关于Hash函数的细节,我们以后再描述,现在我们需要知道就是:一段数据经过Hash函数的运算后,得到一段长度很短的数据,我们称之为摘要数据,可以表示成:
Hash(原始数据)=摘要数据
而Hash函数有以下三个特点:
同样的原始数据,经过同一个Hash函数,总是能得到相同的摘要数据;
原始信息的任何微小的修改,通过Hash函数后,得到的摘要数据会面目全非;
不可逆运算,即:拥有摘要数据,无法逆向反推出原始数据。
比特币的做法是,交易账本数据按照时间分块存储,每一块只存储10分钟的交易账本数据,这每个存储单元即称之为“区块”。而每一个区块的头部会记录这一数据块的序号、时间和Hash摘要数据。
比较巧妙的地方在于,区块头部中的Hash摘要数据是由上一个区块的摘要数据和本区块的交易账本数据叠加后经过Hash函数得到的,即:
第n块的Hash值=Hash(第n-1块的Hash值+第n块的账本数据)
可以看到,虽然每一个区块内的交易账本数据是独立的,但是区块头部的Hash值却是依赖于上一区块的Hash值,从而形成了一条链式的结构。这想必也就是“区块链”名字的由来。
链上的任何一个区块中的数据受到的篡改,都将反映到最新的一个区块的Hash值上,因此,要想验证某个节点的账本数据是否正确,只需要比对最新一个区块的Hash值即可。
2.账户所有权的证明
如果我要通过某个账户给另一个账户转账,必然需要证明我对此账户的所有权。对于中心化的货币系统,我们只需要向银行出示密码即可,但是对于去中心化的系统,如果我们也通过出示密码给其他节点,来证明我们对账户的所有权,那么我们的密码也就泄露给了其他节点。
事实上这是一个现代密码学中比较基础的问题,说白了就是如何在不暴露自己私钥的前提下,自证身份,也有很成熟的解决方法:利用非对称加密算法。关于算法的细节,计划在后面单独说说现代密码学的一些基础算法,这里我们就用类比的方法描述一下。
首先我们来确定要解决的问题:
A要从账户X中转账一笔钱给账户Y,就需要向全网广播一条消息,网络中的其他节点收到消息后,要有方法能够验证广播这条消息的人,确实拥有账户X的所有权。同时,消息中不能包含账户X的密码,否则就意味着账户的控制权泄露给了全网的用户。
解决方法是这样的:
由A向全网发布广播,广播的消息中需要包括:
①原始交易信息
②原始交易信息经过Hash算法后得到的一条摘要信息
③签名
前两条很好理解,关于签名,我们可以这么理解:
有这么个签名函数,输入是打款账户的私钥和②摘要信息,而输出就是③签名,即:
签名=sign(私钥,交易信息摘要)
网络中其他节点收到广播后需要验证A是否有权将账户X中的钱转出去,验证步骤如下:
广播中①原始交易信息中,有打款者的账户地址,这个地址其实就相当于公钥。
相对应于签名函数,还有个校验函数,输入是③签名和公钥,输出则是摘要信息,即:
交易信息摘要=verify(签名,公钥)
只需要比对verify函数算出的交易信息摘要与广播中的②交易信息摘要相吻合,那么就认为广播这条消息的人,拥有正确的私钥,即拥有账户X的所有权。
而通过公钥是无法推算出私钥的,因此也不会有泄露私钥的风险。
标签:比特币区块链比特币中国官网联系方式40亿比特币能提现吗比特币最新价格行情走势区块链工程专业学什么区块链存证怎么弄区块链技术发展现状和趋势
RealVision首席执行官RaoulPal认为,投资者不应将加密货币视为资产,而应将其视为数字国家。在最近的一篇博客文章中,前高盛高管声称加密生态系统是创造内在价值和外在价值的网络.
1900/1/1 0:00:00根据加密货币分析师凯文斯文森的说法,当山寨币市场苏醒时,Chainlink将采取重大举措。Santiment表示,领先的山寨币项目正在发出看涨信号.
1900/1/1 0:00:00非常感谢各位朋友们百忙之中抽出时间来看这篇文章,希望文章对你有帮助,可以关注我和给我留言评论,一起交流本月比特币的波动性较小,因为它的交易价格在18,500美元至19,600美元之间.
1900/1/1 0:00:00还记得热门网络剧《权力的游戏》中的这句名言吗? “冬天来了”。 这是即将发生的麻烦的迹象,很快就会出现在火线上的每个人身上。这就是加密货币市场和投资者的现状.
1900/1/1 0:00:00截至5月1日,BTC的哈希率达到473.87EH/s的历史新高。哈希率的飙升可归因于比特币序号的增加。然而,尽管如此,BTC在撰写本文时仍处于亏损状态.
1900/1/1 0:00:00主要亮点: 加密货币总市值在过去24小时内从1.13T美元增加到1.14T美元,涨幅为0.94%在过去24小时内上涨1.89%后,截至发稿时比特币价格为24.
1900/1/1 0:00:00