清华大学密码学博士吴彦冰带你揭开区块链密码学神秘面纱,了解区块链技术原理
. a0 M; w0 _: `2 t* d
0 t. u O ~5 o$ W$ f; H8 ?4 p4 `/ j" H& k f) h0 X8 ]+ p
3 x- `9 K. V' u0 V
\: }: W0 b. A. ~6 H- |4 e
8 M% ]: M* P: I6 j4 _8 E主持人4 Q1 T* R( h: q( F# ~* }7 k- T, p
我们从中本聪开天辟地之前聊起。我们都知道区块链诞生于比特币,而比特币诞生于密码学。那么纵观密码学发展历史,经典密码学和现代密码学的区别是什么?工作原理是什么?吴博士9 @, b L1 A7 A. {8 J- Z1 k; E3 Z; L/ N. o
经典密码学和现代密码学区别还是非常大的,比如说经典密码学里面最典型代表比如拿凯萨密码来说。我们现在来看他是非常的简单,就有一个相当于是密码表进行置换。我们可以在里面进行一个置换可以将字母A换成C,可以将b换成D,进行一个混淆。解密的时候也是同样的原理,根据密码表反向回来就可以了。凯赛密码,我们是可以通过统计学分析出来的。比如说统计人类最常用的字母是o,假设密文里出现的最多的字母是r,我们就可以很大程度认为o被置换成了r。但是现代密码学就非常的不同,密码的安全性不是想传统密码一样依赖于加密解密的流程,而是依赖于密钥。现代密码学基本上是非常科学的,是基于一些,数学难题或者是数学体系,进行设计的。就比如说RSA就是基于大整数难分解问题设计。椭圆曲线签名就是基于离散对数问题设计的。5 c" j% q" y. j8 f; |+ Q+ }" X
2
; K3 _# e& _9 d+ D8 ~6 q+ p主持人& H3 D3 h) _1 |. G) E
中本聪并不是第一个尝试将密码学加入到货币中的人。在他之前有一些密码学学者有过尝试,比如PMoney等,那么之前关于密码学的加密货币尝试为什么会失败?
, {! A1 k+ l& x, C7 {0 D
# d; Y2 u+ }, D) w4 }. x, w6 E) z吴博士) P4 Y5 a3 d* ] e0 `
最早将密码学用于货币中的应该算是大卫乔的ecash。他使用到了密码学里面的盲签名技术。盲签名通俗的来讲就是签名人不知道自己签名的内容是什么,银行通过盲签名技术来完成铸币工作。ecash之所以失败主要是,最早不能解决双花问题有很大的关系,还有与ecash的性能和可用性上有一些关系。7 v! Z+ {/ K/ ]8 m R& E. u
3
9 a! p- M% I; D% ^! m/ V0 J
3 h% C+ V( `+ f9 O& P1 w+ c$ j2 l e M% b主持人, u4 n' c& J Z8 F! _
5 ~& s& ^/ ] T- {% [2 ]
+ W7 A; d: t6 H/ e/ x
刚说到双花的问题,我想问问为什么会出现双花?比特币是怎么规避双花问题的?# }- D- A0 t/ s9 v& [
9 Q, z2 K/ [/ @, O2 W2 T) R吴博士/ d5 O h) `9 A3 }: A A
7 \7 |4 n* M8 H; B, W+ n& f5 J4 }( V4 ~2 A$ ~7 Y6 ]( s L% v
. d W" W0 J8 `: h双花,即一笔钱被花了两次或者两次以上,也叫双重支付。ecash是通过设计了一种可撤销匿名性的盲签名来解决双花问题的。7 o9 ]; X9 d# ?( D" f
U) e! e7 D3 ^3 D, v! c
在比特币中,双花攻击一般会和51%攻击一起使用。那是怎么实现的呢。比特币会选取最长的一条链来当做主链,我们可以在一个包里打包一个交易比如说我在一个区块里进行一笔交易,这笔交易是转给a的。我拥有了百分之五十一的算力,可以使这个区块进行分叉,我在分叉的区块里进行了另一笔转账,将同样的币转给了b,这样同一个币就花了两次。防止51攻击非常困难,就像互联网中防止DDOS攻击是一样的,但是进行51%攻击的难度也非常大。( g6 J/ Q" F% o! y
; [9 u, ~0 z5 p0 n" H2 ]) ], |
6 z2 ^) V. |: V- t: t4
' p/ V- ?( e6 E3 B% P8 B3 W8 I, V1 s) N
主持人
8 J' h+ B- T, A& y2 ~
+ ^" u9 t8 Y1 _# v3 R/ V4 `& B3 ~ [) p7 Y/ T) X& u
除了双花之外,大家说起比特币,还常提到拜占庭将军问题。所以也想请您给大家科普一些PBFT共识的知识,比特币是如何解决拜占庭将军的问题?( C# k- _; \+ r5 p" M4 o
2 l- i# H7 @6 v2 B吴博士* Z4 K b# N5 ~5 }8 ^% \) U6 m" K
7 D ^" x+ F2 S5 ]3 ]# a7 q
1 p5 X j t7 w, Z1 g
BFT这个问题是在区块链没有产生之前就已经有了,是兰帕德提出来的,是拜占庭将军问题的一个解决办法也是解决计算机中一致性问题的一个解决方案。
( [9 z' }. N; I" r: u- H9 {9 Y* c9 A" L1 R& B# C8 M- C& \
那么什么是拜占庭将军问题,其实拜占庭将军问题是兰帕德的讲的一个故事。古代的拜占庭帝国,他们的军队非常多但是不能集中在一个地方,他们分别住在不同的地方,他们要去发起进攻的时候要同时发起进攻,不然的话就会战败。拜占庭将军问题就是解决驻扎在不同地方的将军如何形成统一的进攻或撤退指令。; z2 v9 N) h) G) L" c! Z# L
0 e. b. G6 T- _% `8 a9 s
主持人这里提到的PBFT,P就是现实可用的,也就是实际可用的拜占庭将军问题解法,因为在PBFT之前提出过很多BFT的解法,但是都不是多项式时间的算法。IBM主导的超级账本中就有使用PBFT作为共识,但是PBFT随着节点的增加,通信成本会大大增加,所以PBFT通常用在联盟链中。
) P& b7 \* J' W. D# |
3 }# Q' h: E5 ?% W$ ^& w* E具体的关于这个拜占庭将军问题我在抖音里面有录三个小视频具体的讲他是怎么解决这个问题大家如果感兴趣可以关注我的抖音wuyanice。
: G/ A# ]9 i. L' ]
( d! V& I, W+ a7 l那么比特币是怎么解决这个拜占庭将军问题的呢,就跟上面我们回答的问题是一样的。比特币通过POW共识来解决这个拜占庭将军问题,相当于有这么多个将军,这些将军共同去计算一道难题,然后谁率先解决出这个问题的答案谁就可以发号施令,大家都要听这个将军的。
% v8 J8 y! @0 I* E) E* ^
5 G( R3 H& H) E/ i
; T+ R* a9 x. C5 K0 e
6 N3 k8 Y% Q) q1 ~1 Q4 r/ _主持人. C# ~# O6 `/ l
我以区块链特性来理解故事中拜占庭帝国将军驻扎的形式就是分布式驻扎所以其实共识是解决问题的关键的。
: K- } a: |2 G- z53 T+ f- U# ~. ]. t! y5 g4 T
; b! _# Y/ g. |/ ]' |8 g主持人
; h7 ?- K( u. p1 n! x- H7 H目前区块链中POW,POS,DPOS共识算法的区别,能不能通俗形象的给大家解释一下?
6 A2 i7 o3 V- @7 U9 g0 R# B, @: j U! p+ @/ E% m2 R
吴博士
. g/ K; C0 _# z/ K6 Z, X* S5 P共识算法最开始是为了使区块链的账本达到一致,最开始中本聪使用的POW这个共识算法,在之前有用过比如像处理垃圾邮件问题里面。POW也叫工作量证明的方法。可以举个简单例子什么是POW,POW就好比是去计算一道数学难题,比如说一加一是难题,我们在规定时间内谁先计算出这道数学难题谁就会获得打包权,谁就可以打包区块,之后可以广播给其他人。POS是什么呢,做一个简单的举例,POS就好比是股份制的公司然后谁拥有的币越多就相当于拥有的股份越多。拥有股份越多就相当于对这个区块链掌控度越高。比如说拥有了百分之八十的币,相当于区块链上的打包百分之八十都听这个节点的。DPOS是什么呢,我们也举一个简单的例子,DPOS就相当于是民主制的选举,最典型的应该就是EOS使用的DPOS,每次社区会选举二十一个超级节点,这些超级节点来管理这个链。+ l& R+ o$ I9 w; h" N- ~
& \0 F8 U, m7 L( n$ g# m主持人) N7 O) F5 ^, B1 X
那我简单总结一下,POW工作量证明就是谁速度最快谁获胜,POS机制是谁实力最强谁获胜,而DPOS机制是谁获得的社区支持更多谁获胜。
! u) s: s0 I0 h6
& T/ p: U+ |, {: t; D" ~( s% z' \8 ^% O) v3 a; o
主持人; K! O' f8 y7 J) Q$ s9 S$ B A/ C
那么除了上面提到的几种共识方式之外,有小伙伴对零知识证明也很感兴趣。什么是零知识证明呢?) P/ y: e$ y3 X6 q
/ I# v; p0 C6 P* d8 r) y吴博士
2 O9 S0 _* Z! J \8 ~# w2 ]
# [, O% E/ D5 C5 B! y; N1 w1 @7 J
, D) Z: X6 D; n/ [零知识证明,具体的来讲其实应该叫做零知识的知识证明。我们就要讲什么是知识证明,知识证明就是相当于,我知道一个知识,我要去向你证明我知道这个知识。那么什么是零知识证明,就相当于是在证明知道这个知识的时候,我没泄露任何关于这个知识的信息,只是想你证明我知道这个知识,但你不知道是什么,你还能相信我是知道的。* ]5 v3 a" K6 ?/ L
2 P9 t" t2 s8 ]$ k. Y* s6 \举个简单的例子来说什么是零知识证明,就比如说阿里巴巴知道开门的咒语但是他要去向强盗证明他知道这个,但是不能把这个咒语告诉强盗,这个就需要用到零知识证明。阿里巴巴会对强盗说你们离我一箭的距离,用弓箭指着我,你们举起右手,我念咒语打开石门,举起左手,我念咒语关上石门,如果我做不到或逃跑,你们就用弓箭射死我。这样强盗就不知道开门的咒语但是又能相信阿里巴巴知道咒语
2 p0 ?& [ k6 w. s; Q
1 @2 [5 x: |; f# L' ^ A- D0 E( p: G# T8 f
7
: S9 q( ~, W+ V1 s
2 J, h, x! a, K% r/ k主持人; p$ E3 F- [2 D5 V' _# G
: F% N" k, c4 \! H d
2 B( P9 k5 D8 o8 S$ x吴总给我们的分享确实是少见的通俗易懂,那么我们在许多介绍零知识的文章里都能看到完备性、可靠性、零知识这样三个特性,但是少有文章给我们解释背后的深意,它的可靠性和面临的挑战又有哪些呢?
) t$ n3 f% C. F6 u9 z
4 N8 \' k4 D; z9 t吴博士: @) R0 X) v2 u) i A) N( l
" N5 {. X+ \0 j/ v Z1 N. [ s: |$ s% q2 V( [! u9 h. m% P5 T
完备性其实是在数学里面给出了很规范的定理。这里我就通俗的解释下什么是完备性,完备性就是说这个证明通过一定的步数之后是可以给出最终答案的,要不接收这个证明,要不然否定这个证明。可靠性就很好理解了,就是说这个证明协议是可靠的,知道知识的情况下可以给出证明,不知道证明的情况下是无法给出证明的。& l- S1 p$ r1 z! T6 c6 K
2 S! k! N" Q' U7 E% g. {零知识性我上面就有提到,就是在给出证明的时候不会泄露任何与知识有关的信息。像zcash就使用了零知识证明来保证匿名性。面临的挑战就是性能和可用性的问题,目前用在匿名上的零知识在产生证明上非常慢。所以无法保证在实际中是可用的,就是说交易的时间会特别长. K5 {: i; f. C' l
1 ~! l( a& K; e4 A! ^, s
' R8 f- E$ C$ y
8
3 m, ?: q' u7 f7 N
_+ S& t$ N& X) G- F主持人" r) ]; m5 Y4 I
# v, q) b. x# Q) B; @. i1 n2 D% O$ l% G/ o
说到匿名性,我想到了隐私保护,也想请问区块链技术和密码学是如何实现隐私保护的?7 j9 w U2 Z6 C8 Y
# E l6 J: |; i+ [吴博士
: F, A( C7 y, y! a4 W( E% B; m( i0 K' x1 w: D2 A/ l1 \
4 g( ^4 [8 X$ b! M, z
最开始的时候比特币被认为是匿名的,但是后来通过一些手段可以分析出来某个地址对应的人是谁,这样比特币就失去了他的匿名性就成为了一个伪匿名的。后来通过密码学手段上有三种方法来实现匿名性,一种方法是通过混币的方式进行的,就是讲所有交易杂糅在一起,最简单的混币就是把币冲进交易所再提到一个新地址。第二种方法就是使用零知识的方法,一个使用零知识证明的最典型的就是zcash。第三种方法就是通过环签名的方式进行匿名,最典型的就是门罗币。3 z) c9 i6 c ?2 w) _% J3 K% O3 J W
: Y* z+ N; w5 |2 G V# i
6 n5 Z; o5 B5 y; L
95 }% @* ]& S2 \& s+ r9 q
# |6 y$ i( s8 o. w8 E% }, T8 E
主持人
& {% n' Y! E8 `# Y) ^% @
! ^2 f" A' {: J3 H4 X) K# D
, O$ ~6 k' k- F2 d众所周知,区块链是依赖于哈希算法和其他加密术,在现有算力下是难以破解的,不过近几年有量子计算机对区块链的影响这个话题一直围绕着我们,看了很多相关的文章说面对量子计算机,现有加密技术面临被破解的危险,那么我也想问问您对量子计算机可能给区块链技术带来的冲击怎么看?
5 l6 r+ x. b' |4 Z; D
* \ K& F% u1 F$ T) T吴博士
7 |6 U" G: ^2 x
4 \; W* B& m6 y* w# q" V9 i8 k1 c+ ~" ^' E# q% x2 O2 ]- G" j. J
量子计算机会给现有的非对称密码带来很大的冲击,因为现有的公钥密码体系都是建立在困难的数学问题上的,量子计算机能在很短的时间内破解这些数学难题。在区块链里主要是交易签名这块。不过已经有很多学者在研究抗量子密码这方面了。9 _+ I/ l! b8 K6 A% w1 G: H/ S
. s |* w8 K6 F* _4 C$ m, ]9 Y
6 @& W8 H. T2 o% j& `, D
10) A/ c- @* ^6 T( j9 E
, s" c. S7 f+ j+ f主持人
) x" Q% o5 L+ o$ H, d0 H& `
0 C* B7 Q; Z0 R& m2 p
J( k5 j' Y/ D: ^5 d也就是说这个冲击是巨大的,那量子计算与区块链之间的关系是挑战还是抹杀?它们各自的优劣势都有哪些?能协作共存吗?
$ q) l4 V8 U) w2 E4 f* L+ S. f$ a% N% [, s- w3 J
吴彦冰
& R# i) m7 A$ d6 p9 v
+ r ^# ~, u+ }, K' p$ n. ~
& \7 E2 D( {. E5 Q7 M就和我上面说的一样,现在很多学者都在研究抗量子的密码算法,有基于格基的。现在的抗量子密码算法中私钥过长,地址也会非常长。但是我相信之后的抗量子密码肯定会用在区块链上,所以大家不用很担心。
% S4 n' S4 a n+ e& n* l( q
. j" C- d$ H, Y5 @1 ^* ~/ T2 r
4 L7 k$ \4 S/ o O11
3 q. |3 Z F# v# I: d8 X! I
, f! A3 i# Q1 M$ E0 d主持人
3 Y: M; ?% |8 p/ w5 A
2 Z$ j2 a& i) A4 h7 [, ^
: B# S6 u8 E4 _, m$ C9 v1 V% E4 K我还有最后一个问题,在区块链这一行,一直有两个圈子,一个是币圈,一个是链圈,币圈通证派的观点认为通证是区块链的灵魂,而链圈的观点认为区块链技术只是去中心化公开透明的账本,安全加密,无需代币,您是怎么看待这个问题的?
" B* t; i% [* h& }
/ ], }- G- F' \, i1 y P( ~吴博士
6 g4 g$ q W. \+ U3 c) i0 _* R, t8 J5 `. O4 m4 t# m. ]
+ ^( K' k! m* ?4 Z; j无币区块链就相当于是分布式账本吧在上面没有任何激励,比如说像IBM提出的超级账本,比如说像一些联盟链中使用的分布式账本。其实这个B在区块链中作用还是非常大的,他相当于是进行一个激励,可能没这个激励的话,这个系统非常非常难以进行运转。但是可以用在一些联盟链中,由特定的节点负责这个链的运转。3 r, d e1 I/ w. g% \0 P. L
9 E3 x8 |. _) ]" Z, m; p0 C1 z* a( }# R+ q
|