本文由“Fairyproof Tech”原創,授權“金色財經”獨家首發,轉載請注明出處。
一份審計報告是對一套智能合約的“質量檢測報告”,那報告就要告訴用戶所審計的對象是誰。
和普通的有形商品不同,智能合約這種特殊的商品是摸不著的,那怎么才能讓用戶知道它呢?
區塊鏈領域的絕大多數項目包括鼎鼎大名的比特幣和以太坊都有一個共同的特點:它們的源代碼都是”開源”的。所謂的“開源”就是它們的代碼都是公開的,放在某個公開、所有人都可以訪問的網站上,任何人都可以看到它的內容。
我們所審計的智能合約絕大多數也是這樣,它們都是開源的,放在一些知名的、供所有人存放文件的網站比如github等。
如果我們所審計的智能合約是開源并且放在了github上,我們要讓用戶知道它、看到它的源代碼,就會在審計報告中列出合約所存放的github的網址。這就好比一件商品存進了一個大倉庫,存在倉庫中的某個庫房,我們要讓用戶能找到這件商品就要告訴用戶倉庫的地址和庫房的門牌號碼。存放合約的github網址就等于倉庫地址+門牌號碼。
獨家 | Bakkt期貨合約數據一覽:金色財經報道,Bakkt Volume Bot數據顯示,4月27日,Bakkt比特幣月度期貨合約單日交易額為919萬美元,環比上漲24%,未平倉合約量為734萬美元,環比下降3%。[2020/4/28]
可是如果合約的編寫者(通常我們稱為項目方)在給審計機構審計時用的是放在github上的一套合約,但審計后尤其是項目上線后,用戶又修改了它的智能合約,我們怎么知道放在github上的合約就是審計時看到的合約而不是后來修改過或者其它“魚目混珠”的合約呢?
這就涉及到github這個倉庫的一個特性了。
當項目方往github中存放代碼時,github會給這次存放動作產生一個版本號。這就好比我們在比特幣、以太坊中申請一個新錢包時,這個錢包會有一個獨一無二的地址一樣,這個版本號也是唯一的。
獨家 | 近30天比特幣搜索指數整體同比上升77%:金色財經報道,百度指數數據顯示,近30天區塊鏈搜索指數整體日均值為4352,整體同比上升24%,移動同比上升21%;比特幣搜索指數整體日均值為25428,整體同比上升77%,移動同比上升95%,以太坊搜索指數整體日均值為4315,整體同比上升16%,移動環比上升23%。[2020/3/1]
當項目方之后對任何文件有了任何改動:小到一個字的修改,大到文件的刪除、添加等,當把這些改動提交到github中,github又會給這次動作產生一個新的版本號。
所以github中的版本號就是對所存放的文件的一份唯一存證,它保證了這個版本號所對應的文件就是某時某刻放進倉庫中的文件,而不是之前或之后放進去的文件。
所以我們在審計報告中除了羅列被審計合約的github網址,還要羅列被審計合約在github中的版本號。
獨家 | 加密貨幣市值前十幣種6漲4跌:金色財經數據顯示,截止當前,加密貨幣市值前十幣種6漲4跌。近24小時漲跌情況分別為:BTC(8765美元,-0.45%)、ETH(224.82美元,-0.29%)、XRP(0.236美元,+2.94%)、BCH(322.54美元,+1.26%)、BSV(226.40美元,+0.86%)、USDT(1.00美元,-0.1%)、LTC(61.39美元,+0.66%)、EOS(3.58美元,+1.06%)、BNB(19.02美元,+2.27%)、Tezos(2.76美元,-0.51%)。[2020/2/28]
這兩個要素就保證了讀者看我們報告時能準確知道我們所審計的內容。
除了放在github上,還有的項目方在審計時已經把合約部署在區塊鏈網絡上了。由于智能合約一旦部署到區塊鏈網絡上,它就是無法篡改和撤銷的,因此智能合約所部署的區塊鏈地址也可以作為合約的存證地址。
獨家 | Bakkt期貨合約數據一覽:金色財經報道,Bakkt Volume Bot數據顯示,2月5日,Bakkt比特幣月度期貨合約單日交易額為1888萬美元,環比上漲32%;未平倉合約量為1294萬美元,環比上漲11%。[2020/2/6]
對這樣的合約,我們通常也會記錄下它在區塊鏈上的地址作為唯一存證。
我們前面說絕大多數項目的智能合約是開源的,這也就意味著還有一些項目的合約在審計時是未開源的,在這種情況下,我們怎么記錄這份合約的存證呢?
我們會用SHA-256的值來標記合約文件的存證。
有些讀者尤其是數字貨幣的玩家看到“SHA-256”這個詞會覺得很眼熟:這不是數字貨幣加密算法中常用的一個技術嗎?
確實是這樣,更準確的說,它是一種經過“哈希函數”運算得出的值,這個值也被稱為“哈希值”,它有256位(bit)。
獨家 | 陶鷗:大量基于以太坊的項目歸零導致以太坊價格下跌:針對近期以太坊價格跳水的現象,金色財經就此事獨家采訪到MATRIX CEO 陶鷗,陶鷗表示,“我認為這一次加密貨幣下跌的原因有三點,首先,加密貨幣市場整體行情震蕩洗牌;其次,以太坊以前是唯一的公鏈,現在有大量更好性能的競品出現,對以太坊的領頭羊地位產生巨大的挑戰;最后,以太坊的最重要應用是ICO,而現在大量通過以太坊ICO的項目破發、歸零,ICO的需求大規模萎縮導致價格下跌。”[2018/8/18]
所謂的哈希函數又稱散列函數(英語:Hash Function),是一種從任何一種數據中創建小的數字“指紋”的方法。哈希函數把消息或數據壓縮成摘要,使數據量變小,將數據的格式固定下來。該函數將原有的數據打亂混合,重新創建一個結果叫做哈希值(hash value、hash code、hash sum或hash)。
我們為什么要用這個值來記錄合約文件的存證呢?因為一個SHA-256的值所對應的文件內容是唯一的。這就和上面我們用github中的版本號來保證github中的文件是唯一的一樣。
那我們怎么用這個值來記錄合約文件的存證呢?
我們自己編寫了一套這樣的工具,對所審計的每個合約文件的內容都用這個工具進行一次運算,所得到的值就是一個SHA-256的值。這個值就代表了我們所審計的文件內容的唯一。
我們會羅列每個文件及其所對應的SHA-256值,這就記錄了文件的存證。
當用戶或讀者要檢測他看到的合約文件是否是我們所審計的合約時,將他看到的文件用我們的工具計算一下,將所得出的SHA-256值與我們所得到的值進行比較,如果一樣就證明是,如果不一樣就證明不是。
所以總結起來說,我們會用github網址+版本號、區塊鏈地址或SHA-256值這三種方式中的一種或幾種來記錄文件的存證。
作者:
Fairyproof TechCEO 譚粵飛
美國弗吉尼亞理工大學(Virginia Tech, Blacksburg, VA, USA) 工業工程(Industrial Engineering) 碩士(Master)。曾任美國硅谷半導體公司 AIBT Inc(San Jose, CA, USA) 軟件工程師,負責底層控制系統的開發、設備制程的程序實現、算法的設計,并負責與臺積電的全面技術對接和交流。自2011至今,從事嵌入式,互聯網及區塊鏈技術的研究,深圳大學 創業學院《區塊鏈概論》 課程教師,中山大學區塊鏈與智能中心客座研究員,廣東省金融創新研究會常務理事 。個人擁有4項區塊鏈相關專利、3本出版著作。
關于Fairyproof Tech:
Fairyproof Tech科技有限公司是一家專注區塊鏈生態安全的公司。Fairyproof Tech科技主要通過“代碼風險檢測+邏輯風險檢測“的一體化綜合方案服務了諸多新興知名項目。公司成立于2021年01月,團隊由一支擁有豐富智能合約編程經驗及網絡安全經驗的團隊創建。
團隊成員參與發起并提交了以太坊領域的多項標準草案,包括ERC-1646、ERC-2569、ERC-2794,其中ERC-2569 被以太坊團隊正式收入。
團隊參與了多項以太坊項目的發起及構建,包括區塊鏈平臺、DAO組織、鏈上數據存儲、去中心化交易所等項目, 并參與了多個項目的安全審計工作,在此基礎上基于團隊豐富的經驗構建了完善的漏洞追蹤及安全防范系統。
還記得此前 Twitter 創始人 Jack Dorsey 拍賣第一條推文的事兒嗎?最終價格出來了,這條人類史上第一條推文,通過 NFT 賣了將近300萬美元的天價! 雖然這條推文的意義重大.
1900/1/1 0:00:00從去年市場行情變熱門之后,就有一些幣圈有人脈的人開始轉型做起來項目代投/私募業務,而從今年開始,這種業務也吸引了很多人去參與.
1900/1/1 0:00:003月23日,央視財經發布題為《一字千金?一條“陳年”推文,竟拍出超1800萬元天價》的文章。文章介紹了Twitter聯合創始人&CEO杰克·多西近日以NFT形式拍賣自己于2006年發布的.
1900/1/1 0:00:00NFT還沒有完全席卷中國市場,但這股熱潮正在蔓延。本周,區塊鏈新聞網站Decrypt記者Da Bing探尋了中國NFT市場狀況,以及加密藝術世界里的各種碰撞.
1900/1/1 0:00:00加密貨幣網絡發展的這幾年,以擴容為特點的項目有很多,不過能作為“標志性解決方案”的并不多,例如以太坊2.0的同構分片,波卡構建的異構分片,Plasma的側鏈.
1900/1/1 0:00:00文章系金色財經專欄作者幣圈北冥供稿,發表言論僅代表其個人觀點,僅供學習交流!金色盤面不會主動提供任何交易指導,亦不會收取任何費用指導交易,請讀者仔細甄別防上當.
1900/1/1 0:00:00