當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導(dǎo)讀] 今天要來簡單介紹一下,門羅幣是怎么達(dá)到匿名交易的。本篇文章會牽涉到橢圓曲線的原理,如果不懂,可以先參考「加密技術(shù)核心算法之安全快捷的ECC算法」。簡單來說就是要知道這樣的關(guān)系: p =

今天要來簡單介紹一下,門羅幣是怎么達(dá)到匿名交易的。本篇文章會牽涉到橢圓曲線的原理,如果不懂,可以先參考「加密技術(shù)核心算法之安全快捷的ECC算法」。簡單來說就是要知道這樣的關(guān)系:

p = k*G ,

p:公鑰

k:私鑰

G:曲線上的基準(zhǔn)點

門羅隱匿交易包含了三個技術(shù):Ring Signature(環(huán)簽名) , Ring Confidential TransacTIons (RingCT,環(huán)保密交易)跟Stealth Address(隱地址)。在Digital Asset Research的文章中這張圖解釋了各個技術(shù)所使用的地方,本篇文章,就是要介紹這三個技術(shù)。

在介紹之前,先了解門羅一些基本概念。在門羅中有兩把key(其實是4把,因為各有私鑰跟公鑰),一把是view key另一把是spend key。顧名思義,一把是拿來看的自己余額的(在鏈上找隱匿位址),一把是拿來花的(做環(huán)簽名)。由spend key可以產(chǎn)生key image(金鑰映像),用來做預(yù)防雙花的證明,有點像zcash的nullifier。

Ring Signature (環(huán)簽名)

環(huán)簽名有點像混幣,就是把好幾筆交易混在一起,不過還是有差異。

那實際上怎么做呢?!假設(shè)一個初始值v,跟一串隨機數(shù)(y1, y2, …, yn),然后把v跟隨機數(shù)經(jīng)由Ek做加密,再把加密過的值跟下一個隨機數(shù)做運算(xor)再加密,如:Ek ( y 2⊕ Ek ( y1 ⊕ v )),所以函數(shù)如下

Ck , v ( y 1, y 2,…, yn )= Ek ( y 1⊕ Ek ( y 2⊕ Ek (… Ek ( yn ⊕ v ))))

接著使Ck , v ( y 1, y 2,…, yn ) = v,也就是v經(jīng)過一連串的計算后,最后會等于自己,這就是環(huán)簽名的基本概念,如下圖形成一個環(huán)

實際應(yīng)用場景會像這樣:

m:訊息

P1, P2, …, Pn:為任意的一組公鑰

1.計算加密金鑰k = Hash(m)

2.選擇隨機數(shù)v

3.為所有的公鑰選擇隨機數(shù)(x1, x2, …, xn)(不包含自己xs),接著計算

yi = gi( xi)。( gi = xi^{Pi} mod Ni )

*也就是上述的隨機數(shù)yi,使用公鑰來產(chǎn)生

4.藉由Ck,v(y1, y2, …, yn)來求得自己的ys

5.接著利用自己的私鑰算出xs,xs = gs^{-1}(ys)

6.最終,輸出環(huán)簽名σ = (x1, x2, …, xs, …, xn, v)

驗證

1.計算yi = gi(xi), i = 1, 2, …, n

2.計算加密金鑰k = Hash(m)

3.驗證Ck,v(y1,y2,…,yn) ?= v

因為v跟ys是相關(guān)的,而只有擁有私鑰的人才能從ys算出xs,因此其他人無法假造簽名。而環(huán)簽名有個特性,就是少了某一項,可以用其他項來算出少的那一項。因為簽名被混合過了,所以礦工無法直接驗證交易是否花過了,要怎么確保雙花的問題?就要借助到金鑰映像(key image)的幫助,實際怎么運作,后面的隱地址一起介紹。

Ring ConfidenTIal TransacTIons(環(huán)保密交易)

在RingCT(環(huán)保密交易)出現(xiàn)之前,因為環(huán)簽名的限制,混合環(huán)簽名的金額必須一樣,所以交易金額都必須被拆成固定面額,例如要交易12.5 XMR,就需要拆成10, 2 , 0.5三種面額,雖然發(fā)送方的資訊有環(huán)簽名做保護(hù),但是交易的金額就暴露給所有人了。

環(huán)保密交易出現(xiàn)后(新版的環(huán)簽名”A MulTI-layered Linkable Spontaneous Anonymous Group signature”所支援),金額將會被遮罩住,因此不必拆成已知面額,進(jìn)而可以達(dá)到隱匿的作用。

Stealth Address(隱地址)

記得上面提到,每個人有兩把key(view key跟spend key)。假設(shè)Alice要轉(zhuǎn)錢給Bob,首先,Alice要利用Bob的public view key跟public spend key組成一次性的公鑰,計算如下

P = H(rA)G + B

r: Alice選的隨機數(shù)

A:Bob‘s public view key

B:Bob’s public spend key

G:橢圓曲線中的基準(zhǔn)點

H:hash function

然后計算R = rG。接著把交易送到P所產(chǎn)生的位址,并將R值放入交易的內(nèi)容。所以整個網(wǎng)路都會知道P跟R。

因為r 是隨機數(shù),每次產(chǎn)生出的一次性公鑰P都會是不同的,而由公鑰P產(chǎn)生出門羅的地址就叫做隱地址(stealth address)。Alice把交易送到隱匿地址后,Bob要怎么知道這筆交易呢?

Bob有view key跟spend key對應(yīng)的私鑰(a, b),Bob計算

P′ = H(aR) + B

因為aR = arG = rA,所以可得P‘ = H(aR) + B = H(rA) + B = P

所以若P’==P就代表這筆交易是給自己的,而這個計算需要a : private view key,所以也就只有Bob可以計算得出來。Bob找到交易后可以算出對應(yīng)的私鑰x = H(aR) + b,就可以動用這筆交易了!而這種方式,對于收款人來說是麻煩的,因為要隨時掃描鏈上的交易,才知道有沒有自己的。(有一種方式,是把自己的view key給第三方,由第三方幫你掃描,不過你的資產(chǎn)就會曝光,但是依然只有自己能動用)

回到雙花的問題上,上面有提到金鑰映像,先來看金鑰映像的算法

I = xH(P)

基本上是由一次性的公鑰P跟私鑰x 組成,每一筆交易P只會對應(yīng)到一把私鑰x,所以對于每筆交易P其金鑰映像I都是固定的,因此礦工只需要去驗證I 是否有重復(fù),就可以驗證是否雙花。

門羅的最新協(xié)議Bulletproof,是一種range proof,主要用于環(huán)保密交易(RingCT),藉由Bulletproof可以大大減少了驗證資料的大小,讓交易資料變小,而手續(xù)費得以減少,有機會再來深入探討B(tài)ulletproof。

擴展性(scalability)是門羅的一個大問題,主要是保密交易使用的rang proof的資料量龐大,使得交易的資料量很大,約是比特幣的10倍(使用bulletproof后),每次交易也都會有新的金鑰映像提供查詢,所有歷史交易的紀(jì)錄都需要保留,無法像比特幣有些技巧可以省略某些交易。這或許對門羅幣是個挑戰(zhàn),但是另一派的說法,門羅幣的交易量不是重點,而是他提供的隱私性。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉