hashcash在比特币中的应用

比特币的支付流程及原理

在比特币的世界里,用户都有一个表示自己身份(或者也叫地址)的标识。这个标识是该用户的公钥信息(用base58做了一层编码)。有公钥就自然有私钥,只不过私钥是不公开的,只有你自己知道(这个很重要哟)。

假设A要给B转账5 BTC(比特币简写),这条信息会在整个比特币网络里广播,收到广播的每个节点(包括A和B本身)都更新自己本地的账本(A减少5 BTC,B增加5 BTC)。这样交易就完成了。似乎很简单。不过很容易就会想到一个问题:如何证明这条广播消息的合法性?

关键是要证明这条广播是由A发出的,而不是其他人。这里就用到了数字签名的原理了:
A会对该条广播用自己的私钥做个签名,网络中的其他节点用A的公钥验证这个签名(数字签名的原理这里就不多说了,不明白的自行谷歌),验证通过后,才会更新本地的账本。

其他人因为没有私钥,所以无法伪造这样的广播。知道私钥的重要性了,如果你的私钥被破解,分分钟倾家荡产啊!

比特币所用的数字签名是基于非对称的椭圆曲线算法,有兴趣的可以研究下。

1.jpg

图片来自网络

签名的数据源

签名的原理虽然这里不多说,但是用于签名的数据源还是要搞明白。

数据源是A的前一笔交易和B的公钥组成的,后者很容易获取,就是B的地址。那么A的前一笔交易怎么理解呢?

2.jpg

图片来自网络

比特币的网络并不会记录每个人的余额,比如A有100个比特币,B有30个比特币。网络里记录的是每个人的交易信息,简单来讲,进账是+, 出账是-。每次交易时把交易遍历一遍就可以知道你有多少钱。

这种机制的核心就是保证了每一笔交易都不是独立的,都要援引以前的交易,所以比特币的交易信息在网络中就以某种链条的方式传递

这里有一条规则,每一笔交易都要把所有的进账用完,然后把余额发送给自己。举个例子,A初始有100 BTC(可以认为是系统初始分配的),然后A要从B那里购买一个商品,需要付给B 20 BTC,A首先会把之前所有的进账用完(100 BTC),然后发现实际付款的金额(20 BTC)和援引的进账不同,就把差额(80 BTC)发送给自己。

双重支付(double spending)

不记录余额是为了防止伪造账簿,篡改余额。有人可能要问了,交易不会被伪造吗。当然有可能。

3.jpg

图片来自网络

如上图,恶意用户A援引一条他的进账信息(Frank 以前某个时间转给他5个比特币,说明他余额是足够的),向B买一个货物,他广播5 BTC付款给了B。同时A又援引同一个进账信息,广播给自己5 BTC。B收到A的转账信息后,发货。

但是由于网络传播时间的差异,网络中的某些节点有可能先收到第二笔广播,然后这条进账信息就会被标记为已使用,而另外一些节点先收到第一笔广播,大家都认为自己先收到的那个是合法的,那就无法确认这5 BTC到底是A的,还是B的。最惨的是B,损失了货物又损失了金钱。

这就是所谓的比特币双重支付陷阱。

在传统的货币体系中,这个问题是非常好解决的,因为有个中心机构(银行)帮你来验证每笔交易,但是比特币的核心就是去中心化,没有这个所谓的中心机构。

如何解决这个问题呢? hashcash终于要登场了!

hashcash的原理可以参考另一篇文章,这里不再赘述。
关于hashcash


区块链和hashcash

区块链的概念:

交易进行时间排序,然后根据排序结果分组,每个组就是一个区块,把这些区块链接起来就是区块链。

4.jpg

图片来自网络

什么是区块的信息

同一个区块的交易是同一时间发生的,交易的数量可以任意。区块内的这些交易唯一的标识了该区块。这个的标识其实就是每笔交易的hash结果的组合。而每笔交易的hash又是由各自交易的信息(比如交易时间,交易的买卖双方地址等)。

除了hash结果的组合,区块中还有其他信息,比如时间戳,随机数等。这个随机数对后面"猜答案"非常的重要,这里先卖个关子。

总之结果就是每个区块都有一个唯一的对外信息。记住这个就行了。

7.jpg

图片来自网络

如何加入区块链

只要一个区块能加入现有的区块链中,它就是一个合法的区块。所以如何加入区块链是关键

比特币网络中的任何节点(比如你自己)都可以生成区块,并且都可以申请加入现有的区块链。

那么比特币网络如何决定区块链的下一个区块是哪一个呢?可能同一时间会有多个不同的节点生成新的区块,所以节点不能依靠接收到区块的顺序来决定。

比特币通hashcash来解决这个问题。

前面提到,每个区块除了基本的交易信息外,还有个随机数,这些信息就是hashcash中所谓的戳记。而这个随机数就戳记的第7域。也就是不断尝试要满足前缀N个比特位都是0这样的条件。(这个N会根据计算机的不断发展而增加已提升难度,达到计算的平衡

5.jpg

图片来自网络

只有当达到了条件才会被接受作为区块链的一环。这也被称为工作证明(proof of work)。生成区块的节点,需要证明本节点投入了足够多的运算资源去求解一个数学难题。

区块链如何防止双重支付

一个交易是否合法关键是能否加入一个有效的区块链。假设A付款给B,B等交易被确认加入一个链中,然后发货。

A伪造了一笔交易,把钱有退回给自己。如果要被整个网络认可这笔交易,A必须自己生成一个比原来的链长的区块链并把这笔交易加入链中。但事实上,这几乎是无法做到的。一台计算机甚至要花几年的时间去"猜"一个区块,而整个网络中的计算机的力量只要几分钟就可以解出来。个人要想伪造一笔交易达到双重支付s要跟整个比特币网络竞争。你的计算速度再快,也不可能快过整个网络。

6.jpg

图片来自网络

矿工

前面提到攻击者需要和整个比特币网络的计算能力竞争,这个计算能力的贡献大部分就是来自一些个人或者组织(现在大部分是组织了,个人很少),他们通过贡献自己的计算资源来求解区块。这些组织我们称之为矿工。旷工的存在让比特币的整个系统更加安全。矿工的作用是验证交易和维护区块链。而他们工作的奖励就是比特币。

区块链越长越安全

这个很好理解,一个交易处于链中越靠后的位置,就越难被篡改。因为比特币网络只接受最长的一条区块链作为有效的区块链,这样,对于攻击者来说,引入一个虚假区块不仅需要解一个数学问题,而且需要和其它正常的节点竞争,生成所有的后续节点才能使其它节点接受自己的区块链作为有效链,这变得几乎不可能。

参考
[1] https://bitcoin.org/bitcoin.pdf

[2] http://www.hashcash.org/papers/hashcash.pdf

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,783评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,360评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,942评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,507评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,324评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,299评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,685评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,358评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,652评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,704评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,465评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,318评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,711评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,991评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,265评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,661评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,864评论 2 335

推荐阅读更多精彩内容