以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads
首頁 > 幣贏 > Info

比特幣:如果量子計算時代到來,我們的比特幣安全嗎?

Author:

Time:1900/1/1 0:00:00

撰文:李畫、安比實驗室創始人郭宇

校正:郭宇

來源:鏈聞

每次有量子計算的新聞出現時,人們都要擔心一次比特幣。原因很簡單,比特幣是基于密碼學的,而密碼學之所以能夠成立,是基于某種計算上的不可能性。如果量子計算把原本不可能或難以實現的計算變成可以計算,那么這種密碼學的方法就會失效。

但這種擔心是多余的。原因同樣簡單:我們只要有量子計算也無法完成的計算,不就可以嗎?以這種計算為基礎構建的密碼學方法,量子計算也就無法破解,然后把比特幣升級到該密碼學方法之下即可。

「格困難問題」就是典型的代表,即便對于量子計算,它也保持著計算上的不可能性。基于人類的「無知」,我們很大程度上總可以找到方法生活在密碼學的保護之下。

比特幣中的密碼算法

我們知道比特幣錢包地址對應一個公鑰和一個私鑰,只有擁有私鑰才能動用該錢包中的比特幣,但私鑰是安全的,它無法通過錢包地址或公鑰被計算出來。

這是如何實現的?讓我們從臺球廳開始。

你去臺球廳打臺球,把一個球放在臺球桌底邊的一個位置上,就叫它A點,然后你把這個球打出去,假設你擊球的力氣超級大,那么球從A點出發,總會撞到臺球桌某條邊上的一個點,然后又會從該點彈到臺球桌另一條邊上的另一個點……它可能這樣彈了B次,最后停在了臺球桌某條邊的一個點上,就叫它C點。

Filecoin開發人員:大礦工測試競賽中 如果偽造地址將無法獲得獎勵:7月22日,在北京時間9:00開始的Filecoin礦工社區電話會議上,Filecoin開發人員表示,在Space Race中,中國社區的礦工需要VPN才能參與競賽,并且需要驗證礦工所在地區。如果礦工偽造其所在地區地址,將無法獲得獎勵。[2020/7/22]

這時候你的朋友來了,他能看見臺球在C點的位置,你告訴他這個球最初的位置A點和擊球的角度,問他這個球中間彈了多少次,也就是B是多少?你的朋友應該一時回答不上來。

這就是一個簡單的公、私鑰生成算法,C是公鑰,B是私鑰。在我們知道A點和B次彈跳的情況下,是能得到C點的;但如果我們只知道A點和C點,是很難算出彈跳次數B的。

在真正的密碼學中,臺球桌的邊被換成了橢圓曲線,A是橢圓曲線上一個固定的點,它擊打自己,球在橢圓群里撞來撞去撞了B次,最后落在了橢圓群的一個點上,還要對該點再做一次映射,有了橢圓群上的一個點C。C是公鑰,B是私鑰。

這就是著名的橢圓曲線算法,被用于生成公鑰、私鑰,是比特幣系統中的第一個密碼學方法。

橢圓曲線算法難以被破解,但并非不能被破解,足夠強大的量子計算可以找到多項式算法,通過A和C計算出B,也就是可以通過公鑰算出私鑰。所以,如果真的進入到量子計算時代,橢圓曲線算法是需要被新的抗量子計算的算法替換的。

Messari前主管:如果你對DeFi不感到驚訝,那么你是沒有注意到它的神奇之處:Messari前主管、股票及加密貨幣交易員Qiao Wang今日發推稱,如果你對發生在DeFi的事情不感到驚訝,那么你是沒有注意到。是的,費用很高。是的,結算時間長。是的,流動性很低。是的,它們中的大多數甚至都沒有去中心化。但是,沒有任何語言可以描述開放和無許可的界面是多么神奇。[2020/7/15]

量子計算與橢圓曲線算法

比特幣采用的橢圓曲線數字簽名算法的安全性是2^128。這是個天文數字。

在量子計算的情況下,使用PeterShor提出的Shor算法,它攻擊橢圓曲線的復雜度大概是O(log(N)^3),對于比特幣而言,理論上的計算量級是128^3次。

相關論文研究顯示,構造一個攻擊secp256-k1曲線的量子計算機,假設該計算機能把比特錯誤率降低到10^-4,那么有希望在使用170萬個量子比特的情況下,在7天之內完成計算。

在比特幣系統中,還有另一個密碼學方法,哈希函數SHA-256,它被用于生成與公鑰對應的錢包地址。該算法很好理解,就是把一個輸入以一種不可逆的方式轉換成一個輸出,它有非常強的單向性,想通過輸出來計算輸入是不可能的。

因此,哈希函數只能通過暴力的方式破解,也就是變換輸入值一次次去試,直到可以用某個輸入值算出目標輸出值。

聲音 | 騰訊首席探索官:如果區塊鏈不能對全球性挑戰起到幫助作用,CXO團隊就不會涉足:金色財經報道,騰訊首席探索官(CXO)網大為表示,我基本上不太會投資這種像區塊鏈、AI(人工智能)、VR(虛擬現實)等平臺級服務,我都是投資一些解決具體問題的公司,技術只是解決問題的手段。我的工作重點是應對全球性的挑戰,在這個語境下,區塊鏈其實是一種工具,問題就在于如何讓這種工具對各種全球性的挑戰起到幫助作用。如果區塊鏈不能對這些領域產生重大影響的話,CXO的團隊就不會涉足這個領域。[2019/12/26]

相較于經典計算機,量子計算機在暴力搜索上具有可觀的優勢,不過仍然是一種多項式級別的性能優化,我們可以通過加倍安全位數,比如采用SHA-512來維持安全性。

比特幣錢包地址是公鑰經過兩次哈希計算得到的,一次是?SHA-256,一次是RIPEMD-160,量子計算很難攻破兩道哈希關口,通過錢包地址「撞」出公鑰。量子計算與SHA-256目前在量子算法里可以加速計算SHA-256的是LovGrover在1996年提出來的Grover算法,它可以將暴力搜索的性能提高到平方倍。假設我們要在一個N×N的巨大方格里尋找一根針,經典計算機需要逐一搜索每一個方格,最壞情況下需要搜索N×N次;但Grover算法即使是在最壞的情況下也只需要搜索N次。總結一下:比特幣中有兩種基礎密碼算法,一是橢圓曲線算法,一是哈希函數SHA-256。目前能夠找到前者的高效量子計算方法,實現破解;但并沒有找到后者的高效量子計算方法。當然,破解的前提是量子計算真的發展到足夠強大,要知道,谷歌最新的量子芯片只有54個量子比特。

聲音 | 摩根大通區塊鏈負責人:如果美聯儲推出數字貨幣,愿意“殺死”JPM Coin:摩根大通數字財政服務和區塊鏈負責人Umar Farooq表示,如果美聯儲推出自己的數字貨幣,他將很愿意“殺死”摩根大通的貨幣(JPM Coin)。話雖如此,Farooq補充表示,它(美聯儲的數字貨幣)必須“精心設計”,否則可能會導致當前的商業銀行體系面臨風險。(Business Times)[2019/11/12]

我們的比特幣安全嗎?

如果進入到量子計算時代,我們只需要用抗量子計算的密碼學算法生成公鑰、私鑰、錢包地址即可。但假如用戶未能升級公鑰私鑰,他們錢包中的比特幣是否就一定會被竊取?答案是否定的。

大致有如下幾種情況:

1.如果錢包地址中的比特幣從未被使用過,那么該地址的公鑰是不被人知曉的,其他人所知道的只有錢包地址。如前文所述,SHA-256是難以被量子計算破解的,這意味著其他人是無法通過錢包地址算出公鑰的。所以,即使可以通過公鑰算出私鑰,那些沒有暴露過公鑰的錢包地址也是安全的。

2.如果有好的比特幣使用習慣,一個錢包地址只使用一次,那么同理,新地址的公鑰也是不被人知曉的,新地址中的比特幣是安全的。

3.如果用戶重復使用一個錢包地址,那么該地址對應的公鑰就處于暴露狀態;如果量子計算破解了橢圓曲線算法,那么該地址中的比特幣就面臨被竊取的危險。

比爾·蓋茨:如果可以的話,我將做空比特幣:據新浪財經報道,微軟聯合創始人比爾·蓋茨表示:“如果可以的話,我將做空比特幣,我沒有持有任何比特幣。”蓋茨解釋稱,作為一種資產,沒有生產任何東西就不應該期望它會上升,這是一種純粹的“傻瓜理論”式投資。蓋茨補充說,有人曾在他生日時給他一些比特幣,但幾年后他就賣掉了。[2018/5/7]

據統計截止到當前,有將近500萬個比特幣是存放于公鑰暴露的地址中的,此外還有將近177萬個比特幣使用的是P2PK地址,這是最早期的比特幣賬戶格式,公鑰是公開的,其中就包括被認為是中本聰的賬戶。如果這些比特幣不更換地址,它們是在量子計算攻擊范圍內的。

除了錢包地址,在比特幣系統中還有一個重要的地方使用到了SHA-256,那就是挖礦。挖礦就是暴力破解哈希函數的過程,通過調整輸入值「撞」出落在目標區間的輸出值。

如前文所述,從理論上講,量子計算機芯片在暴力搜索時是可以「碾壓」經典計算機芯片的,但我們同樣需要考慮到它的技術發展水平和芯片制作工藝。此外,芯片本就是隨著技術的發展不斷升級的,量子計算對挖礦的影響更多的是芯片升級的經濟問題,而不是安全問題。

量子計算下的安全:格密碼

在量子計算發展的同時,量子安全密碼學也在飛速發展,這其中最具代表性的是「格密碼」,它是基于格的密碼體制。

「格」是一個系數為整數的向量空間,可以把它理解成一個高維度空間,它有兩個基本的「格困難問題」,一是最短向量問題,一是最近向量問題,求解這類問題需要指數時間的復雜度,那么如果因子為多項式,這類問題就不存在多項式時間算法,對于量子計算也是一種計算上的不可能性。

這聽起來有些抽象,也許可以這么去理解:用筆在一張A4紙上畫出很多黑色的點,然后換支筆在紙上畫下一個紅色的點,我們需要做的是找到距離紅點最近的黑點,這很容易;現在從A4紙這個二維空間到一個三維空間,想象一下空間里漂浮著很多黑色的點,這時放一個紅色的點進去,同樣是去找距離紅點最近的黑點,這并不算很難,但相對于二維空間,其困難度已經不在一個級別了。

現在,我們把三維空間變成一個三百維的空間,給定一個紅點去找距離它最近的黑點,這個黑點一定存在,但想想看,找出它是不是幾乎不可能?這就是格困難問題。

格空間與橢圓曲線是相似的。在橢圓曲線上,可以有數學公式把公鑰和私鑰放在一個等式的兩頭,在格空間里,也有數學公式可以把類似黑點和紅點的東西放在一個等式的兩頭,那么我們就可以利用這類公式來生成公鑰和私鑰。

在橢圓曲線算法中,因為「離散對數困難問題」,傳統計算機無法通過公鑰計算出私鑰;在格密碼的算法中,因為「格困難問題」,量子計算機也無法通過公鑰算出私鑰。

格密碼發展很快,基于格我們不僅有抗量子計算的公鑰和私鑰,還有抗量子計算的對應于經典密碼概念的一系列密碼學算法或協議,它們可以被用于數字簽名、密鑰交換、零知識證明等等應用領域。

宇宙相信加密。加密容易,解密難。」

在可以預見的未來,依然如此。所以,不用擔心,對于比特幣是這樣,對于區塊鏈也是。參考資料

Arute,Frank,KunalArya,RyanBabbush,DaveBacon,JosephC.Bardin,RamiBarends,RupakBiswasetal."Quantumsupremacyusingaprogrammablesuperconductingprocessor."?Nature?574,no.7779(2019):505-510.

AndreasM.Antonopoulos答疑量子計算問題:www.youtube.com/watch?v=eo7mwcsUbdo;www.youtube.com/watch?v=wlzJyp3Qm7s

Gentry,Craig."Fullyhomomorphicencryptionusingideallattices."In?Stoc,vol.9,no.2009,pp.169-178.2009.

Aggarwal,Divesh,GavinK.Brennen,TroyLee,MiklosSantha,andMarcoTomamichel."QuantumattacksonBitcoin,andhowtoprotectagainstthem."?arXivpreprintarXiv:1710.10377?(2017).

Stewart,I.,D.Ilie,AlexeiZamyatin,SamWerner,M.F.Torshizi,andWilliamJ.Knottenbelt."Committingtoquantumresistance:aslowdefenceforBitcoinagainstafastquantumcomputingattack."?RoyalSocietyopenscience?5,no.6(2018):180410.

Regev,Oded."Lattice-basedcryptography."InAnnualInternationalCryptologyConference,pp.131-141.Springer,Berlin,Heidelberg,2006.

Tags:比特幣SHACOIOIN比特幣最新價格行情以太坊實時行情DollarBalance Sharekucoinpro是什么Zild Finance Coin

幣贏
BAS:在質疑中求變,Libra的貨幣籃子如何落地?單一錨定取代綜合錨定?

作者:小蔥姐 來源:小蔥區塊鏈 Libra仍然充滿著不確定性,此前與一籃子貨幣錨定的它曾被稱之為“世界貨幣”,也有人稱它是“美元霸權的延續”,Libra背后的貨幣籃子如何落地.

1900/1/1 0:00:00
人工智能:人民網評“解析區塊鏈”之二:如何占據創新制高點

作者:葉蓁蓁 來源:人民網 2018年我國已擁有全球超八成的區塊鏈專利,但是,不要高興太早,在基礎理論、產業生態、人才培養等方面,我們的短板日益凸顯.

1900/1/1 0:00:00
300:華為本月已公開4項區塊鏈相關專利

作者:奚習習 來源:財經網鏈上財經 新浪財經今日消息,據天眼查信息顯示,華為近日申請了“基于區塊鏈的結算方法、區塊鏈節點和客戶端”專利.

1900/1/1 0:00:00
數字貨幣:區塊鏈徹底引爆中國股市、幣市,神奇還能延續多久?

在區塊鏈技術正式上升為國家戰略之后,整個區塊鏈市場迎來了久違的瘋狂,28日早上9點,約90只區塊鏈概念股在第一時間集體漲停。 股市的瘋狂,其實早已在上周末已經確定.

1900/1/1 0:00:00
NFT:兩小時跌幅達500美元,昨晚比特幣暴跌可能有這三個原因

比推消息,北京時間周三晚間市值最高的加密貨幣比特幣的暴跌可能有三個原因。加密媒體Cointelegraph刊文稱,周三比特幣的價格由8000美元附近跌至7500美元附近,兩個小時內跌幅達500美.

1900/1/1 0:00:00
BOOK:歐盟發布文件草案,建議考慮歐洲數字貨幣

作者:XiranDing來源:比推bitpush.news編者注:原標題為《歐盟提出建議考慮歐洲數字貨幣的草案》歐盟發布的一份文件草案建議歐盟考慮發行自己的數字貨幣.

1900/1/1 0:00:00
ads