智能合約安全如何保證?

寫在開頭

????在我寫這遍文章的時候订框,距離EOS曝出漏洞已經(jīng)有三天時間析苫,區(qū)塊鏈行業(yè)熱點來的快去的也快,每每出現(xiàn)安全相關(guān)問題布蔗,都會給整個行業(yè)帶來震蕩藤违。自從我開始關(guān)注區(qū)塊鏈行業(yè)以來,安全事故有增無減纵揍,交易平臺顿乒、智能合約、共識機制等等都成了安全事故的中心泽谨。

????但是近年來璧榄,智能合約明顯已經(jīng)被黑客死死盯上了。從前年的THE DAO再到今年的BEC吧雹。與此同時網(wǎng)上也出現(xiàn)了很多不同的聲音骨杂,有人為智能合約的巧妙性叫好,有人也為智能合約的安全性唱衰雄卷。本文不會對智能合約本身優(yōu)劣進行探討搓蚪,只針對如何保證智能合約安全來進行深入,歡迎留言討論丁鹉。

第一部分:智能合約基本原理

????智能合約本質(zhì)是一段運行在區(qū)塊鏈網(wǎng)絡(luò)中的代碼妒潭,它完成用戶所賦予的業(yè)務邏輯悴能。通俗的來說,相當于是一個“不可改變”且“公正”的“中間人”雳灾。舉一個例子漠酿,我跟你打一個賭,如果明天下雨谎亩,算我贏炒嘲,如果明天沒下雨,就是你贏了匈庭。然后我們在打賭的時候就把錢放進一個智能合約控制的賬戶內(nèi)夫凸,第二天過去了,賭博的結(jié)果出來了以后嚎花,智能合約就可以根據(jù)收到的指令自動判斷輸贏寸痢,并進行轉(zhuǎn)賬。這個過程是高效紊选,透明的執(zhí)行過程啼止,不需要公正等第三方介入。

????比如我們熟悉的以太坊兵罢,它的智能合約業(yè)務邏輯就是代幣發(fā)幣和交易献烦。以太坊在設(shè)計之初,將智能合約設(shè)計成了一旦部署就不能修改的模式卖词。這種設(shè)計是為了提高智能合約的可信性巩那。但是只要是人編寫的程序,不可避免的就會產(chǎn)生漏洞此蜈。所以即横,當有漏洞出現(xiàn)時,想要再挽回損失就很大了裆赵。

第二部分:智能合約安全

????前面講到东囚,智能合約本質(zhì)就是一段代碼,并且發(fā)布之后不可修改战授。若在發(fā)布之后發(fā)現(xiàn)了嚴重的漏洞页藻,就只能重新部署新的合約,這對廠商來說代價太大了植兰。那么要想這段保證代碼的安全份帐,就一定要在發(fā)布之前對智能合約進行代碼審計。除開需要第三方的代碼審計之外楣导,團隊在開發(fā)的過程中废境,也是有方法可以用來提高智能合約的安全。

1.? 代碼一定要測試!

2.? 代碼一定要review噩凹!

????不要看小看這簡單的兩點朦促,絕大多數(shù)的代碼問題都能在這個過程中發(fā)現(xiàn)。下面我將白帽安全研究院給出的如何避免開發(fā)業(yè)務層代碼安全問題放在下面栓始。有需要的可以一一對應對自己的代碼做一個審核。

1.? ?盡量避免外部調(diào)用

2.? ?仔細權(quán)衡再發(fā)生重要操作時的代碼邏輯血当,避免邏輯陷阱

3.? ?處理外部調(diào)用錯誤

4.? ?不要假設(shè)你知道外部調(diào)用的控制流程

5.? ?標記不受信任的業(yè)務內(nèi)容

6.? ?正確的使用斷言

7.? ?小心整數(shù)除法的四舍五入

8.? ?不要假設(shè)業(yè)務創(chuàng)建時余額為零

9.? ?記住鏈上的數(shù)據(jù)是公開的

10.? 在雙方或多方參與的業(yè)務應用中幻赚,參與者可能會“脫機離線”后不再返回

11.? 明確標明函數(shù)和狀態(tài)變量的可見性

12.? 將程序鎖定到特定的編譯器版本

13.? 小心分母為零

14.? 區(qū)分函數(shù)和事件

15.? 避免死循環(huán)

16.? 升級有問題的業(yè)務層代碼

????除了自己對代碼的審核外,請第三方安全機構(gòu)進行審核也是很必要的臊旭。智能合約審計嚴格意義上上來說落恼,是應該有個非常規(guī)范的流程。一半情況至少會對以下四點進行審核:

1. 函數(shù)可見性審核

2. 合約限制繞過審核

3. 調(diào)用棧耗盡審核

4. 拒絕服務審核

????通過這四點的審核离熏,至少能把隱私泄露佳谦、交易溢出與異常、合約故障和拒絕服務的問題解決滋戳。大大減少智能合約帶來的安全風險钻蔑。

第三部分:第三方智能合約審計

????目前有提供智能合約審計和代碼審計的安全公司還不太多,我從平時看的一些快訊里收集到奸鸯,列出目前比較出名的幾家在做智能合約審計的安全廠商咪笑,供大家參考。

知道創(chuàng)宇:為火幣娄涩、Bit-Z提供了合約代碼復查服務和云防御服務窗怒。

慢霧科技:為EOS提供節(jié)點安全部署和安全審計。

360:據(jù)悉曝出EOS漏洞后開始參與代碼審計蓄拣。

白帽匯:目前暫不知曉與誰合作扬虚。

寫在最后

  本文只是對智能合約和智能合約審計做了一個非常淺薄的分析。并且區(qū)塊鏈行業(yè)安全問題牽扯到了方方面面球恤。智能合約只是里面的一小部分辜昵,后續(xù)會繼續(xù)寫一些區(qū)塊鏈行業(yè)其他的安全問題,歡迎一起探討碎捺。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末路鹰,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子收厨,更是在濱河造成了極大的恐慌晋柱,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件诵叁,死亡現(xiàn)場離奇詭異雁竞,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門碑诉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來彪腔,“玉大人,你說我怎么就攤上這事进栽〉抡酰” “怎么了?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵快毛,是天一觀的道長格嗅。 經(jīng)常有香客問我,道長唠帝,這世上最難降的妖魔是什么屯掖? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮襟衰,結(jié)果婚禮上贴铜,老公的妹妹穿的比我還像新娘。我一直安慰自己瀑晒,他們只是感情好绍坝,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著苔悦,像睡著了一般陷嘴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上间坐,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天灾挨,我揣著相機與錄音,去河邊找鬼竹宋。 笑死劳澄,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蜈七。 我是一名探鬼主播秒拔,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼飒硅!你這毒婦竟也來了砂缩?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤三娩,失蹤者是張志新(化名)和其女友劉穎庵芭,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體雀监,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡双吆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年眨唬,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片好乐。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡匾竿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蔚万,到底是詐尸還是另有隱情岭妖,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布反璃,位于F島的核電站区转,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏版扩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一侄泽、第九天 我趴在偏房一處隱蔽的房頂上張望礁芦。 院中可真熱鬧,春花似錦悼尾、人聲如沸柿扣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽未状。三九已至,卻和暖如春析桥,著一層夾襖步出監(jiān)牢的瞬間司草,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工泡仗, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留埋虹,地道東北人。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓娩怎,卻偏偏與公主長得像搔课,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子截亦,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容