以太坊交易所 以太坊交易所
Ctrl+D 以太坊交易所
ads
首頁 > DOT > Info

金色觀察|Spartan Labs研報:基礎SBT以及隱私性SBT的實現_NBS:區塊鏈

Author:

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

文/ Yong Kang Chia和Jun Hao Yap,Spartan Labs,標題:The Construction of the Soul Part 2: Implementations of SBT

這是一個由三部分組成的系列文章,介紹SBT的基礎知識、對SBT的愿景、其技術實施以及利用ZK技術的可能性。系列文章的目標是揭開SBT技術思想的神秘面紗,并提供一種實現來構建具有社會身份集成的Web3未來。第1部分討論什么是SBT及其基本特征(參閱金色此前翻譯文章“SBT基礎知識和潛在案例全解析”)。第2部分討論其基礎實現以及如何使用SBT添加隱私。第3部分將討論如何使用ZK技術來改善SBT隱私。

本文為其第2部分,將根據第一部分提出的設計指導原則談一談SBT的實現。

1、實現思路     1.1 與NFT的比較     1.2 基礎SBT           → 1.2.1 鑄幣和銷毀           → 1.2.2 鏈下存儲           → 1.2.3 驗證SBT屬性           → 1.2.4 更新 SBT 數據           → 1.2.5 基本使用SBT           → 1.2.6 SBT對隱私的需求2、具有私有數據存儲的SBT      2.1 將數據存儲在鏈上但對地址進行散列           → 2.1.1 示例用法           → 2.1.2 討論具有鏈上散列的 SBT     2.2 存儲IPFS 等第三方提供商的鏈下項目           → 2.2.1 將鏈下數據與鏈上哈希鏈接連接          → 2.2.2 鏈下秘密的風險。3、結論

金色午報|7月17日午間重要動態一覽:7:00-12:00關鍵詞:區塊鏈產業、推特被黑、吳忌寒、信標鏈

1.婁底市加快推進區塊鏈產業發展政策正式出臺。

2.蘇州市相城區成立10億元區塊鏈專項引導基金。

3.深圳硅基揚航公司成立 吳忌寒出任法定代表人。

4.推特被黑幕后黑手或為21歲英國小伙 曾協助劫持杰克多西賬戶。

5.推特:約有130個賬戶被作為目標 已于受害者進行合作。

6.Grin已完成第三次硬分叉升級。

7.紅嶺云與阿里云簽署“黨建+區塊鏈”框架合作協議。

8.BSN發展聯盟理事長:BSN北京區塊鏈主干網落戶大興。

9.以太坊聯合創始人:信標鏈安全性對ETH2.0至關重要。[2020/7/17]

在本小節內容中,我們將討論SBT的實現及其利弊權衡。

既然NFT和SBT聽起來確實很相似,那么在具體實現方面,這些數據結構之間的關鍵區別是什么呢?

不可轉移性

與被設計為可交易的NFT不同,SBT在本質上應該與靈魂綁定在一起,應該是不可轉移的。

隱私保護

NFT的數據是公開的。然而,SBT項目可能希望保留其數據的私有性。

隱私可以通過各種不同方法實現。

可組合性

SBT的數據應該很容易被其他鏈上或鏈下項目讀取。

以SBT特性為指導原則,我們在Solidity中實現了SBT。(https://github.com/SpartanLabsXyz/spartanlabs-contracts/tree/main/contracts/SoulBoundToken)

我們將在下面小節內容中討論我們的實現。

基礎SBT可以作為模板供其他希望在SBT上構建的項目使用。基礎實現不涉及隱私方面的討論,隱私相關內容將在本文的第2節中展開。

金色晨訊 | 6月17日隔夜重要動態一覽:21:00-7:00關鍵詞:ETF、加拿大央行、西班牙議會、BTC挖礦難度、ETH、澳本聰

1. WisdomTree申請推出ETF,或將5%投資于比特幣期貨。

2. 加拿大央行在招聘公告中透露CBDC計劃。

3. 西班牙議會計劃就新加密交易所監管法進行投票。

4. BTC挖礦難度已上調14.95%至15.78T。

5. 報告:ETH活躍地址達到2018年1月水平。

6. Mt.Gox前首席執行官:澳本聰不是小偷就是騙子。

7. 美聯儲主席鮑威爾重申利率將維持在零附近。

8. 泰國政府將通過區塊鏈向公眾發行儲蓄債券。

9. 國網四川將召集25家電廠要求治理違規直供電礦場。[2020/6/17]

1.2.1 鑄造和燒毀

合約是這樣設計的:鑄造應由項目所有者把關。這是為了防止用戶可以鑄造任何SBT信息帶來的潛在漏洞,比如用戶會鑄造一個良好的信用評分,但這并不是項目的意圖。這個想法是,項目應該確定、驗證和鑄造與SBT相關的正確數據。

同樣,對于與地址相關聯的SBT的燒毀,我們也認為用戶不應該具備輕易刪除其數據的能力,特別是當該數據包含某個負面屬性時。用戶應該能夠提議燒毀他們的SBT,但燒毀的執行應該由項目所有者決定。

那些希望允許用戶選擇刪除數據的項目可以實現燒毀。例如,如果一個用戶出于與項目的目標不一致,想要從項目中刪除所有信息,那么他應該擁有這樣的選項。

另一個需要考慮的問題是,項目可能希望管理他們的SBT社區,并在用戶違反他們的社區管理條款、條件時刪除用戶。例如,在一個發布SBT的社區中,也許會有用戶不遵守規則并表現出不適當的行為。因此,社區可以決定是否從其項目中刪除用戶的SBT。這樣的社區可能希望進一步實現一個建議機制,以允許刪除數據的自燃建議或燒毀其他人SBT的建議。

金色午報 | 6月4日午間重要動態一覽:7:00-12:00關鍵詞:北京市市長、日本金融服務局、比特大陸

1.北京市市長:綜合運用區塊鏈等技術賦能健康醫療服務。

2.日本金融服務局:未經注冊向公眾提供加密資產投資建議等屬違法行為。

3.詹克團方面啟用新公章 欲收購比特大陸公司員工手中期權。

4.TravelRule或阻礙加密貨幣完全走向主流。

5.海關監管區塊鏈技術落地山東自貿試驗區青島片區。

6.國網河北信通公司開展區塊鏈技術應用研究支撐數字新基建。

7.嘉楠推出新礦機A1146Pro即將推出A1166Pro。

8.研究人員破解2015年445枚BTC被盜案相關地址。

9.比特幣小幅震蕩,日內最高報9689美元,最低報9517.62美元。[2020/6/4]

1.2.2 鏈下存儲

數據可以存儲在鏈上或鏈下。在我們的實現中,我們假設SBT的數據存儲在鏈下,由IPFS作為供應方。在我們的實現中,鏈下存儲的URI可以與數據結構“Struct Soul”中的標識符相結合。

項目能夠根據他們是想在鏈下還是鏈上存儲SBT屬性來調整提議結構。

1.2.3 SBT屬性驗證

其他交易對手項目應該能夠輕松檢索SBT數據。

這對于想要驗證用戶SBT屬性的交易對手來說很有用。其他項目將能夠查驗一個地址是否綁定了靈魂,并驗證該靈魂所包含的屬性。

這對于SBT與不同項目的可組合性非常重要,其他項目可能希望進行交互并驗證用戶的屬性。但是,用戶和項目可能不希望公開數據,有一些方法是可以保護數據隱私的。

1.2.4 SBT數據的更新

金色晨訊 | 12月27日隔夜重要動態一覽:21:00-7:00關鍵詞:聯通、阿里巴巴、巴哈馬、以太坊Jeffrey、YouTube

1. 山東省委書記:山東正聚焦區塊鏈等前沿科技。

2. 證券日報:明年或成區塊鏈應用集中落地年份。

3. 聯通成都分公司黨委書記:目前聯通有113項區塊鏈技術專利。

4. 2019年阿里巴巴有526條區塊鏈專利申請數據。

5. 互金協會舉辦“區塊鏈技術發展態勢與金融場景應用”培訓班。

6. 德國將要求數字資產托管人申請獲得許可。

7. 法國金融市場管理局發布數字資產服務提供商許可新規。

8. 巴哈馬將于周五啟動數字貨幣試點項目。

9. 以太坊聯合創始人Jeffrey Wilcke向Kraken轉賬9.2萬枚ETH。

10. YouTube:錯誤地清除了加密貨幣相關視頻,已開始著手恢復,未更改與其相關的政策。[2019/12/27]

我們不希望用戶或其他方更新靈魂,我們希望由經許可的權威方來更新,因為我們希望對數據的更改能得到驗證。

由項目來實現合約,這樣用戶可以在鏈下提議對靈魂的更改,再由項目來驗證更改是否有效并更新鏈上更改內容。

1.2.5 基礎SBT用例

SBT的基礎實現適用于希望將數據分配給非私有用戶的項目。例如,想要獎勵白名單對NFT收藏的支持的項目可以使用基礎SBT。在未來,這類項目可以空投獎勵到這些SBT地址。

在之前的文章中,我們提出了如何將SBT作為識別NFT Locker的潛在用例。

例如,當NFT在TimeLock.sol中被鎖定時,Locker可能仍然希望“顯示”他們確實擁有這樣一個鎖定的NFT。然而,從開發人員的角度來看,引用鎖定的NFT是很奇怪的。因此,“靈魂綁定”代幣可以表示出用戶鎖定NFT的時間,它們可以被允許進入“hall of fame”。在解鎖時,一個不可轉移的包裝代幣需要被“燃燒”來解鎖NFT,并且Locker將不再具有“hall of fame”地位。

金色財經現場報道 中國銀行原副行長王永利:比特幣從設計思路上違背社會發展邏輯 不可能成為真正貨幣:金色財經現場報道,在2018全球首屆萬國區塊鏈技術博覽會上,中國銀行原副行長王永利進行《區塊鏈、數字幣需要關注的核心問題》主題演講。他指出:比特幣區塊鏈自2009年一直安全運行至今,比特幣能否成為真正貨幣的問題引人關注。當今的貨幣體系更加強調貨幣價值尺度的基礎功能,力求貨幣幣值相對穩定。比特幣模擬了黃金,但大量死亡幣和被收藏幣難以與社會發展水平相適應,難以保持幣值相對穩定,從設計思路上就違背了社會發展的邏輯和規律,不可能成為真正的貨幣。[2018/4/21]

1.2.6 SBT的隱私需求

然而,上述的基礎SBT并沒有考慮到隱私方面的需求。

正如在前一篇文章中提到的,web3的未來必將要與你的真實身份進行一定程度的集成。因此,鏈上集成后保持個人身份的隱私是至關重要的,這樣才能保護自己免受來自惡意行為者的傷害,比如,惡意行為者可查看區塊鏈的公共數據,還原個人身份。

任何記錄在鏈上的關系都可以立即被全世界的任何人看到,而不僅僅是參與者。通過關聯SBT數據,惡意行為者可以從靈魂中還原用戶的真實身份。

例如,如果人性證明得到更廣泛的應用,保護隱私將變得更加關鍵,因為另一種景象是,我們所做的一切都將在鏈上直接與一張人臉相連。

V神在其研究文章中提出了一些可能實現的具有隱私性的SBT,可以通過鏈上存儲和鏈下存儲來實現。

在本節內容中,我們將討論SBT數據私有存儲的可能實現方式。

將數據項存儲在一個地址中,該地址是以下數據的哈希值:(1)索引、(2)收件人地址和(3)專屬于收件人的秘密。

你可以向一個接口透露你的秘密,然后它會搜索屬于你的所有可能的數據項,但沒有人會知道哪些具體項是你的,除非你自己泄密。

用戶提供的秘密將允許平臺找到與用戶的SBT相關的所有數據。

這種方法也稱為密鑰散列消息身份認證(HMAC)。它是通過對數據和共享密鑰運行加密哈希函數獲得的消息身份驗證碼。

為什么這個方法會奏效?以太坊地址由Keccak -256散列生成,并以十六進制數表示。Keccak -256散列的最后20個字節用于生成地址。

因為一個十六進制數是4位,所以我們將Keccak 256散列的最后40位作為我們的地址。我們可以在這個地址部署我們的項目。

但是,請注意,帶有隱私數據的哈希應該在鏈外執行,因為區塊鏈上的所有內容(包括私有狀態變量)都是公共的。

因此,在進行部署或鑄造時,應該只提供哈希值,而不提供隱私數據。

(上圖為如何在一個特定地址上進行用戶隱私數據布署)

2.1.1 范例

例如,Bob希望使用基于信用的借貸dApp鑄造一個SBT。

借貸平臺首先對Bob執行KYC驗證。

部署地址是由Bob的客戶ID、他的鏈上地址和他的名為“Peanut”的秘密(隱私內容)生成的。

Bob的客戶ID、地址和秘密被哈希在一起,以獲得一個用于數據部署地址的地址。

然后在部署地址鏈上部署一個包含Bob的KYC數據的SBT。

除了知道Bob秘密的人,沒有人可以查看Bob的KYC數據。

當一個項目想要查看Bob的KYC數據時,Bob需要做的就是提供他的秘密“Peanut”,這樣他們就能夠獲得Bob的所有KYC數據了。

2.1.2 關于SBT鏈上哈希的討論

優點:

該方法允許與協議輕松互操作,因為我們所需要的只是檢索數據項所需的秘密、索引和地址。

缺點:

然而,將數據項部署到特定地址是件麻煩事,而且要消耗的大量的gas費。

此外,將所有與SBT相關的數據都存儲在鏈上沒有意義,有些數據可能更適合存儲在鏈下。

更重要的是,用戶的秘密掌握在項目方手中;長期使用可能會導致泄密,類似于如今常見的密碼泄露。

正如上一節提到的,把大多數數據存儲在鏈上成本太大。因此,更好的方法是將數據鏈下存儲在第三方平臺(如IPFS或其他云服務)上。這種在鏈下存儲數據的方法非常類似于NFT,NFT的數據通常也是存儲在鏈下的。

不同之處在于,為了確保隱私,我們首先必須使用加密哈希函數(如SHA256)對URI字符串進行哈希。URI數據的哈希應該在鏈下完成,因為區塊鏈上的所有數據都是公開的,甚至是私有的狀態變量也是如此。

為了防止暴力攻擊識別包含鏈下數據的鏈接,哈希值不應該僅僅是鏈接本身的哈希值。它可以是用戶秘密的函數,與鏈下數據存儲鏈接,或者使用遞歸哈希或其他方法。這也被稱為salting(加鹽)。

下面是使用SHA256的Python實現示例:

這只是一個實現示例。還有許多其他方法可以模糊URI,例如隨機附加秘密、生成隨機秘密、peppering(加胡椒),以及使用專門為安全存儲密碼而設計的其他算法。

然后使用數據的哈希值進行SBT的鏈上部署,而不是使用數據本身。

2.2.1 連接鏈下數據與鏈上哈希鏈接

我們怎樣才能將鏈下數據與鏈上哈希鏈接連接起來呢?

對合約所有者來說,一種可能的方法是將存儲在鏈下位置的數據結構標準化。因此,SBT的所有者可以透露鏈下數據的鏈接,而項目(不一定與部署人員相同)可以哈希鏈接,以檢查它是否與鏈上哈希值相同。如果哈希值相同,項目可以進行查詢來檢索存儲在鏈下位置的數據。

為了保護用戶的秘密,對包含用戶數據的鏈接的驗證必須由可信的、安全的第三方在鏈下完成。

2.2.2 鏈下秘密風險

鏈下傳輸秘密可能使用戶暴露于漏洞和各種攻擊之下。

項目必須確保秘密傳輸的安全,并防止常見的攻擊,如回放攻擊、中間人攻擊和許多其他常見攻擊。

一旦處理SBT檢索的第三方的安全性遭到破壞,個人的秘密就會公開。

項目還應注意網絡釣魚攻擊,因為用戶可能會被提示在復制原始密碼的惡意網站上輸入密碼。

此外,證明用戶具有某種屬性的唯一方法就是公開秘密。但是,為了創建SBT的匿名組合性,使不同的協議可以檢索SBT數據,用戶應該公開必要的最小數據量。

如果項目所需的只是驗證某個屬性,那么用戶不應該透露全部秘密。用戶應該將他們的秘密向盡可能少的項目披露。

因此,我們需要考慮另一種方法,在這種方法中,項目能夠驗證用戶具有某個屬性,而用戶則不會泄露他們的秘密。

在本文中,我們基于本系列第1篇文章中介紹的設計指導原則,介紹了SBT的實現。我們實現了基礎SBT以及具有鏈上和鏈下私有存儲的SBT。然而,鏈下存儲可能并不是真正的私有,因為用戶將不得不公開他們的秘密,以證明他們擁有某種屬性。

ZK(零知識證明)技術的使用可以幫助我們減少用戶的秘密分享量,以保持他們的SBT數據真正的私有性。這就引出了本系列文章的第3篇內容,在第3篇文章中,我們將介紹使用zk-SNARK實現的SBT,在這種實現中,用戶的秘密可以保持隱藏狀態,防止受到各種方式的攻擊。

PANews

DeFi之道

成都鏈安

金色早8點

Bress

財經法學

鏈捕手

Tags:NBSBSPSBT區塊鏈NBS幣BSP幣sbtc幣最新消息行情ruff幣區塊鏈最新消息

DOT
以太坊:合并之前 期間 之后_ETHW:EETH

我們已經討論合并計劃六個月了。期間討論了關于它是如何被推遲的,它會導致什么等等。最重要的是,關于這個事件的重要性我們討論的是最多的。終于,在9月15日,期待已久的合并終于發生了.

1900/1/1 0:00:00
Polkadot 官方發文:公布 10 大開發主題及上線時間_POLK:polkadot怎么讀音發音

隨著 Polkadot 社區進入 2022 年最后一個季度,我們想向社區更新我們一直在研究的一些重要的開發主題.

1900/1/1 0:00:00
藍籌 NFT 項目大額融資之后都有怎樣的規劃?_NFT:NFTBlackmarket

撰文:Babywhale,Foresight News近一個月的時間里,多個藍籌 NFT 項目獲得了數千萬美元甚至過億美元的融資,在市場上引起了諸多關注.

1900/1/1 0:00:00
以太坊最后一個測試網真的合并成功了嗎?_DEFI:以太坊和瑞波幣在中國合法嗎

今日,以太坊完成了合并之前最重要的一個測試之一,加密世界即將迎來一場極為重要的變革。作者:不會跑路的路路原文:《Goerli測試網合并真的成功了嗎?》今日,以太坊完成了合并之前最重要的一個測試之.

1900/1/1 0:00:00
盤點九個衍生品 DEX 新秀:訂單簿模式仍占主流_RES:DEX

頭部去中心化交易所 Uniswap 的交易量已經接近 Coinbase 等中心化交易所,但在加密衍生品(主要為永續合約)交易上,去中心化交易所占有的比例還相對較低.

1900/1/1 0:00:00
河南省搶占元宇宙賽道 發布最新行動計劃_元宇宙:人工智能

繼上海、深圳、武漢、重慶、廈門、沈陽、北京等多地政府陸續出臺關于元宇宙的專項產業發展計劃后,河南省也正式加入其中.

1900/1/1 0:00:00
ads