比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads
首頁 > FTT > Info

比特幣算法進化為Schnorr簽名算法是進步嗎?_CDS

Author:

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

歷史的車輪滾滾向前,技術的進步從未停歇,一次具有里程碑意義特幣協議的開始了它的技術升級。其協議中的技術升級SchnorrSignature和Taproot已集成到BitcoinCore0.21.0?版本中。

比特幣的未來似乎面臨從未有過的光明,現在它有機會不僅通過其容量而且通過其功能超越所有其他區塊鏈。

當比特幣ECDSA橢圓曲線簽名算法時,多重簽名交易驗證過程非常繁瑣,現在可以把一筆交易中的所有簽名和公鑰通通合并成單個簽名和公鑰,無法追溯并且簡單快速會是怎樣?

其實在此之前,中本聰在設計比特幣協議時,需要考慮到簽名算法的簽名長度、是否開源、是否有專利、是否經過足夠長時間的安全驗證、性能等多種條件。當時能滿足上述這些條件的數字簽名算法不止有ECDSA,還有SchnorrSignature這個從各個方面都不亞于ECDSA的數字簽名算法。但是由于在2008年之前處于專利保護的狀態,所以可能是這個原因使得中本聰在設計比特幣協議時并未使用該簽名算法,最終選擇了橢圓曲線數字簽名算法,還在其他專家的建議下選擇了一條特殊的橢圓曲線secp256k1。

時隔10年,2018年7月,比特幣開發者PieterWuille撰寫了bip-schnorr提出了將bitcoin的簽名算法更改為schnorr方案。Schnorr與ECDSA雖然同為使用secp236k1曲線的橢圓曲線加密算法,但由于SchnorrSignature在密碼學特性上的優勢,可以在幾乎同等安全的基礎上,更方便的構建多簽名交易。

Schnorr?使用在比特幣上,相比ECDSA會有一些額外的顯著優勢:

更安全:在隨機預言模型中很容易證明Schnorr簽名的安全性,而ECDSA不存在這樣的證明。

無延展性困擾:ECDSA簽名是可延展性的,第三方無需知道私鑰,可以直接修改既有簽名,依然能夠保持該簽名對于此交易是有效的。比特幣一直存在延展性攻擊,直到SegWit激活后才修復,前提是使用segwit交易,而不是傳統交易。BIP62和BIP66對此有詳細描述。

10多年前活躍的230萬枚比特幣仍未售出:金色財經報道,?Glassnode發推稱,早期的比特幣投資者他們的持有的時間超過 10 年,且并沒有出售他們的BTC。上一次活躍的錢包數量是在十多年前,也就是在2012年及更早的時候,現在已經有了很大的增長,儲存在錢包里的比特幣已經達到了2,386,849.127個幣的歷史最高水平。

在那些日子里,現在被稱為全球市值最大的加密貨幣是唯一的加密貨幣,而且價值不到100美元。此外,神秘的比特幣創造者中本聰(Satoshi Nakamoto)那時還在,在論壇上和通過電子郵件與開發者交談。(u.today)[2022/2/12 9:46:55]

線性:Schnorr簽名算法是線性的!以這一特性作為基礎,可以構建更高效和隱私性更強的區塊鏈系統。使用Schnorr簽名的各方可以生成對其各自密鑰的簽名聚合。例如,N個公鑰進行簽名,采用ECDSA的話,則有N個簽名,驗證同樣需要做N次。若使用Schnorr,由于線性特性,則可以進行簽名疊加,僅保留最終的疊加簽名。例如同一個交易無論輸入數量多少,其均可疊加為一個簽名,一次驗證即可。

Schnorr簽名算法幾乎在各個層面均優于比特幣現有的簽名算法ECDSA:性能,安全,體積,擴展性等方面等,并且SchnorrSig可以與ECDSA使用同一個橢圓曲線:secp256k1curve,升級起來的改動非常小。

當然在比特幣協議中除了簽名算法之外,還設計了Taproot腳本語言定義如何使用比特幣。比特幣多簽類地址可以不用暴露出自己的「多簽」身份,也可以支持數量眾多的多簽場景,降低很多的交易字節數,特別是對于需要高頻操作的地址而言,降低鏈上的交易費用,可以節省不少的成本。

下面是一些比較常見的問答:

Q&A

Q:Schnorr簽名是否可以用在mofn多重簽名上?A:當然可以。多重簽名只是mofn的簽名數量的模式。與簽名算法無關。

Q:Schnorr的組簽名特性是否可以做或模擬出mofn式的簽名?A:無法做到。組內有N把公鑰,則必須對應有N個簽名,缺一不可。每個人在生成簽名的時候,在哈希函數里都代入的都是組公鑰P。

報告:加密鯨魚或在此輪比特幣暴跌中扮演了重要角色:在比特幣此輪暴跌中,加密鯨魚的作用不可小覷。根據Arcane Research報告,3月12日,曾有一名十年前的比特幣礦工將1000 BTC轉移至交易所。這些資金轉移后,比特幣的價格開始大幅下跌。報告還稱,另一個值得注意的鯨魚運動與PlusToken有關。在3月7日至8日期間,逾1.3萬枚比特幣通過混幣服務被發送到交易所。這些BTC可能被拋售,并會持續更長的一段時間,這也可能是3月12日周四市場暴跌的部分原因。而根據Digital Assets Data的一份報告,鯨魚錢包的數量平均增加了,但其實每次減半的年份都是如此,2020年也不例外。(AMBCrypto)[2020/3/15]

Q:簽名機制的安全性如何衡量?A:主要取決于兩個:1.簽名算法本身2.橢圓曲線。目前,Schnorr與ECDSA都用的是曲線secp256k1,這個層面一樣。至于簽名算法本身安全性,Schnorr目前有安全證明,安全優于ECDSA。

BCH上的

Schnorr簽名算法

早在2019年5月16日BCH已經開始進行硬分叉升級。升級的主要內容是Schnorr簽名算法和隔離見證復原,Schnorr簽名升級中最受期待的功能,而隔離見證復原則是一項修復性技術,用來找回被錯發到隔離見證地址的BCH。

開發人員MarkLundeberg用戶不必生成新地址就可以開始使用Schnorr簽名。升級帶給BCH的優勢如下:

提高簽名數據的有效性:

由于簽名是64字節的數據,與通常的70字節相比,交易可以減少4%的字節,該功能基本上提高了每筆比特幣現金交易所需的簽名數據的有效性。并且升級后,Schnorr簽名給BCH帶來隱藏普通支付渠道的能力。

隱私性的提升:

在升級之前很多用戶就會故意使用多個簽名來發送交易來提高隱私,而Schnorr簽名會使所有用戶的簽名看起來和任何其他簽名一樣,這種結構導致了交易隱私性的大幅提升。Schnorr提供的屬性以及BCH開發人員和基礎設施提供商添加的一些延展程序將進一步增強隱私和可擴展性。

行情 | 比特幣期貨COT周報:空頭因素依然占據主導:本周比特幣期貨COT報告中,賣方(Dealer)賬戶的多頭倉位基本與上周持平,說明市場中的空頭因素依然占據主導。大型投資基金(Asset Manager)的凈多頭倉位由260手下降至188手,空頭頭寸由86升至149,這一升一降體現的是多頭勢力的衰減與空頭力量的增加。機構多空比從上一周的3.02繼續回落,本周為1.26。綜合來看,市場中空進多退,空頭因素又現加強的趨勢。10月末以來的消息面利好正在被逐漸消化,短線比特幣可能會繼續回調,大幅上漲概率不大。[2019/11/9]

對抗垃圾交易攻擊:

在過去曾出現一種垃圾交易攻擊,攻擊者希望通過盡可能多的交易空間來使比特幣擁堵,他們的手段之一就是通過頻繁地從多個來源發送交易使這個交易中包括數十個簽名,這些簽名占據了很多的空間,這是ECDSA簽名留下的隱患。

Schnorr可以規避這類的垃圾交易攻擊。如果每一筆交易只有一個簽名,那么區塊就能容納更多交易,垃圾交易制造者要想制造攻擊就必須發送更多交易,與更多人進行競爭,因此攻擊成本就會相對更高。簽名所占空間通常是一筆交易最大的一部分,所以攻擊者不具優勢。

當然我們不能只看到好的一面,全則必缺,極則必反。尤其是量子計算機的發展對區塊鏈安全造成威脅,為了應對量子計算機對一些算法的攻擊,在2017年,NIST就開始了后量子密碼學標準化進程,其中由瑞士ABCMint數學算法基金會推動的抗量子簽名方案,后量子加密基金會支持的抗量子算法之一,最短簽名長度的簽名抗量子簽名方案——彩虹簽名Rainbow最被看好。

2017年8月,JinLiu和數學家Prof.JintaiDing籌建ABCMint,并注冊在瑞士蘇黎世附近的加密谷。其數字貨幣ABC底層簽名便是彩虹簽名Rainbow,他們愿景是在全球支持抗量子計算機破解算法的研究和應用,研究包括在全球支持數學家在算法方面的發現、破解、完善等,應用包括將合適的算法應用在主流數字加密貨幣方面。

行情 | BitMEX比特幣期貨空頭合約1分鐘內平倉超500萬手:據BitMEX交易所數據顯示,北京時間11點16分,比特幣期貨(XBT)空頭合約1分鐘內平倉超500萬手;比特幣短線拉升,最高觸及6580美元,現Bitfinex交易平臺報6566.3美元,24小時漲幅2.28%。[2018/9/14]

他們認為比特幣從ECDSA改為Schnorr簽名的提案BIP340,采用Schnorr簽名,是比特幣的重大退步。不看好由計算機安全專家提出的算法選擇和改進,我們更偏重由數學家提出的算法選擇和改進,Schnorr簽名的問題很大,應該用在Litecoin之類先長時間試車。

BTC應等BCH,或其他鏈再用幾年Schnorr簽名再看看。Schnorr簽名最主要的優點是“多簽時簽名長度最短”,但缺點是“多簽時,最后一個人容易欺騙”。

在密碼學看來:采用Schnorr簽名是一個"膽大不審慎”的做法,背離了”長期安全“的第一要義。

從密碼學角度看待Schnorr簽名主要是為了多簽名,而多簽名適合的場景應該是:既中心化又極其重要的場景,其極其重要的場景類似于核彈發射的十幾道Verifiableprocedure。或夏延山核武基地之類的大門。而不應該是去中心化場景,或比特幣的發送這類場景。

簡單說:去中心化的,本身和多簽名是背離的。

下面來簡單科普一下幾種算法:

橢圓曲線數字

簽名算法

橢圓曲線數字簽名算法是使用橢圓曲線密碼對數字簽名算法的模擬由NealKoblitz和VictorMiller于1985年發明),ECDSA首先由Scott和Vanstone在1992年為了響應NIST對數字簽名標準的要求而提出。

比特幣目前使用的是ECDSA橢圓曲線數字簽名算法,要對消息m進行簽名,我們需對其進行哈希操作,并將此哈希視為一個數字:z=hash(m)。我們還需要一個隨機或隨機查找的數字k。我們不喜歡信任隨機數生成器,因此,我們通常會使用RFC6979,并根據我們的秘密和我們要簽名的消息,計算確定性K值。

行情 | 比特幣全網未確認交易共5000多筆:據btc.com數據顯示,目前比特幣全網未確認交易數量為5213筆,比特幣全網算力目前為38.89EH/s,24小時交易速率為2.37?交易/秒。截至目前比特幣全球均價為6227.48美元,最近24小時漲幅為0.49%。[2018/7/14]

使用私鑰pk,我們可以為包含兩個數字的消息m生成簽名:r和s=(zr?pk)/k。然后,使用我們的公鑰P=pk×G,任何人都可通過檢查點(z/s)×G(r/s)×P的x坐標等于r,來驗證我們的簽名。

簽名驗證包括反轉和兩點乘法,這些操作的計算量非常大。在比特幣中,每個節點都必須驗證所有交易。這意味著當你廣播一筆交易時,數千臺計算機將不得不驗證你的簽名。而簡化驗證過程將是非常有益的,即使簽名過程會更加困難。

第二,每個節點必須分別驗證每個簽名。如果是m-of-n多重簽名交易節點,則可能需多次驗證相同的簽名。例如,具有7-of-11多重簽名輸入的交易將包含7個簽名,并且需要對網絡中的每個節點進行7-11次的簽名驗證。同樣,這樣的交易會占用大量的空間,你必須為此支付大量的費用。

Schnorr簽名

Schnorr簽名算法是由德國數學家、密碼學家ClausSchnorr提出。并于1990年申請了專利,U.S.Patent4,995,082,該專利與2008年2月失效。目前該算法可以自由使用。

Schnorr簽名的生成則略有不同,我們使用了一個點R和一個標量s來代替兩個標量。與ECDSA相似的是,R是橢圓曲線上的一個隨機點。簽名的第二部分計算略有不同:

s=khash(P,R,m)?pk.這里的pk是你的私鑰,而P=pk×G則是你的公鑰,m是消息。然后可通過檢查s×G=Rhash(P,R,m)×P來驗證這個簽名。

這個方程是線性的,所以方程可互相加減,并且仍然有效,這就給我們帶來了幾大關于Schnorr簽名的好處。

Schnorr簽名的批量驗證

要驗證比特幣區塊鏈中的區塊,我們需確保區塊中的所有簽名都有效。

對于ECDSA簽名算法,每個簽名都必須單獨驗證。也就是說,如果區塊中有1000個簽名,我們就需要計算1000次倒置和2000次點乘運算,總共約3000次繁重的計算任務。

而通過使用Schnorr簽名,我們可以將所有簽名驗證方程相加,從而節省一些計算能力。對于有1000個簽名的區塊而言,我們需驗證:

(s1s2…s1000)×G=(R1…R1000)(hash(P1,R1,m1)×P1hash(P2,R2,m2)×P2…hash(P1000,R1000,m1000)×P1000)

這里我們有一堆加法以及1001次點乘法。我們需要為每個簽名計算大約一次繁重的計算。

Schnorr簽名的密鑰聚合

我們希望讓自己的比特幣保持安全,所以我們可能希望使用至少2個不同的私鑰來控制我們的比特幣。比如說一個放在筆記本電腦或手機,另一個則放在硬件錢包/冷錢包。因此,當其中一個受到威脅時,我們仍然可以控制我們的比特幣。

目前,它是通過2-of-2多重簽名腳本來實現的,這需要在交易中包含兩個單獨的簽名。而使用schnorr簽名,我們可以使用一對私鑰(pk1,pk2),并生成一個與共享公鑰P=P1P2=pk1×Gpk2×G對應的共享簽名。要生成這個簽名,我們需要在每個設備上選擇一個隨機數,生成一個隨機點Ri=ki×G,將它們相加以計算一個公共哈希(P,R1R2,m),然后從每個設備(si=kihash(P,R,m)?pki)中獲取s1和s2。然后我們可以將這些簽名相加,并使用一對(R,s)=(R1R2,s1s2)作為我們對共享公鑰p的簽名。其他所有人都無法說出它是否是聚合簽名,它看起來與普通schnorr簽名完全相同。

這種構造有3個問題,第一,從用戶界面的角度來看,要進行交易,我們需要進行幾輪通信,計算公共R,然后-簽名。有了兩個私鑰,只需一次訪問冷錢包就可以完成:我們在在線錢包上準備一個未簽名的交易,選擇k1,將R1=K1×G與未簽名的交易一起記下。然后我們將這些數據傳送到冷錢包并簽名。因為我們已經有了R1,所以我們可以一次性在冷錢包上簽署交易。從冷錢包中,我們得到了R2和s2,并將其傳輸回在線錢包。在線錢包使用之前選擇的(k1,R1)簽署交易,結合簽名并廣播簽名交易。這與我們現在的情況非常相似,但一旦添加第三個私鑰,一切就會變得更加復雜。比方說,你有一筆財富,它是由10個私鑰控制的,它們存儲在世界各地不同的安全位置,然后,你需要進行一筆交易。目前,你只需要瀏覽所有這些位置一次,但如果你使用的是密鑰聚合,則需要執行兩次,以組裝所有RI,然后簽名。在這種情況下,最好在不進行聚合的情況下保留單獨的簽名,然后我們就需要3輪通信:

選擇一個隨機數ki和相應的Ri=ki×G,然后只告訴每個人其哈希ti=hash(Ri),這樣每個人都可以確定在學習了其他隨機數之后你不會改變主意;

把所有的數字匯總起來,計算出共同的R;

簽名;

第二個問題是已知的惡意密鑰攻擊。無論是在論文還是這篇文章中,都有很好的描述,所以我不想詳細討論。其想法是,如果你的某個設備被黑客攻擊,并假裝其公鑰是,那么它可以用它的私鑰pk1控制共享資金。一個簡單的解決方案是,在設置設備時,需要使用相應的私鑰對公鑰進行簽名。

還有第三個重要問題。不能使用確定性k進行簽名。有一種簡單的攻擊方式,如果你使用確定性K,它允許黑客獲得我們的私鑰。攻擊看起來會是這樣的:有人入侵了我們的筆記本電腦,并完全控制了兩個私鑰中的一個。我們可能覺得是安全的,因為我們的比特幣需要來自pk1和pk2的聚合簽名。因此,我們嘗試像往常一樣進行交易,準備一個未簽名的交易和R1值,將它們轉移到我們的硬件錢包并在那里簽名。然后返回和……我們的在線錢包發生了一些事情,它無法簽名和廣播。我們再次嘗試,但我們被黑的電腦這次使用了另一個隨機值R1'。我們再次與我們的硬件錢包簽署相同的交易,并將值帶回我們被黑的電腦。然后,糟糕的事就發生了,我們的比特幣就丟失了。

在這個攻擊中,黑客為同一筆交易獲得一對有效的簽名:(R1,s1,R2,s2)和(R1',s1',R2,s2'),這里R2是相同的,但R=R1R2和R'=R1'R2是不同的,這意味著黑客可以計算我們的第二個私鑰:s2-s2'=(hash(P,R1R2,m)-hash(P,R1'R2,m))?pk2andpk2=(s2-s2')/(hash(P,R1R2,m)-hash(P,R1'R2,m))。我發現這是密鑰聚合最不方便的特性:我們需要在任何地方使用好的隨機數生成器來使用密鑰聚合。

彩虹簽名

Rainbow是一種多變量簽名方案,它的分層結構以不平衡石油-醋栗簽名方案為基礎。Rainbow層所施加的額外結構使該方案面臨更多的密碼分析技術,但提高了該方案的效率。Rainbow提供了快速的簽名和驗證以及非常短的簽名,但具有非常大的公鑰。

選擇Rainbow增加了入圍簽名方案的多樣性;但是,由于密鑰尺寸非常大,Rainbow不適合作為通用簽名算法來替代目前出現在FIPS186-4中的算法。特別是,大公鑰使得證書鏈非常大。然而,有些應用并不需要經常發送密鑰。對于這樣的應用,Rainbow提供了小而快的簽名。

參考文獻:

https://panzhibiao.com/2019/02/28/schnorr-sigature/

https://mp.weixin.qq.com/s/wy1jtKzNVdmiccd4e9N3Ew

https://medium.com/cryptoadvance/bls-signatures-better-than-schnorr-5a7fe30ea716https://medium.com/cryptoadvance/how-schnorr-signatures-may-improve-bitcoin-91655bcb4744

Tags:SCH比特幣DSACDSHeroesChained科比特幣閃崩之后帶給我們怎樣的maidsafecoincds幣是什么意思

FTT
金色早報 | 灰度創始人:接受基金資產達$1000億挑戰_區塊鏈

頭條 ▌灰度創始人:灰度接受基金資產將達到1000億美元的挑戰彭博資深ETF分析師EricBalchunas在推特發起調查稱:“你認為其中哪幾家公司的基金資產會達到1000億美元?”結果顯示.

1900/1/1 0:00:00
萬字長文梳理以太坊的結構性_以太坊

2020年對整個世界都是充滿挑戰的一年。與此同時,事實證明它對以太坊卻給予了比較積極的影響——以太坊的生態系統在許多方面都沒有減弱,朝著我們的市值邁進了一大步.

1900/1/1 0:00:00
AEX安銀恢復FIRO充提幣公告_AEX

親愛的AEX安銀小伙伴:FIRO已于FIRO網絡區塊高度336,888進行硬分叉及網絡升級,現已升級完成,自發布公告起,已恢復充提。溫馨提示:數字資產是創新型的投資方式,風險較高,專業性較強.

1900/1/1 0:00:00
關于AIB-45天愛的奇跡理財第10期公告_AMV

尊敬的用戶: WBF瓦特寶將于新加坡時間2021年1月20日15:00上線AIB定期理財活動,詳情如下: 活動說明: 1.本次認購僅支持APP端.

1900/1/1 0:00:00
Gate.io 已經完成當日為用戶轉化分發1.3萬枚FIL代幣公告_GATE

Gate.io今日已經根據用戶FIL6持倉情況完成FIL分發,總計約1.3萬枚,用戶可在賬戶賬單明細中查看詳情.

1900/1/1 0:00:00
幣安礦池第26期雙幣寶理財產品上線_USDT

親愛的用戶: 幣安礦池上線第26期“雙幣寶”理財產品,邀您體驗!申購方式:先到先得申購時間:2021年01月20日中午12:00至2021年01月21日中午12:00理財產品列表 數字資產 周期.

1900/1/1 0:00:00
ads