BCH客戶端Bitcoin-ABC 分叉漏洞分析

漏洞描述

在2018年4月26日上,Bitcoin-ABC 的開發(fā)者被不明身份的人告知牧牢,當前 Bitcoin-ABC 0.17.0 版本存在漏洞。如果被利用,這個漏洞會導致 Bitcoin Cash 網(wǎng)絡意外分裂录平。

對于此漏洞的描述大致如下:

攻擊者會構造一個被 Bitcoin-ABC 0.17.0 版本所接受并且能夠打包進 block 的惡意交易。 這個 block 將被其他相互兼容版本的 Bitcoin Cash 實現(xiàn)拒絕缀皱。 惡意交易的 signature hash 類型中的0x20的比特標志位會被設置斗这。

漏洞分析

在 commit c3804927eb8a中,他們重構sighash類型測試來檢查交易簽名中可能存在的每個值啤斗。

圖1.png

通過上圖表箭,我們可以分析得出:之前是& 0x1f, 但是構造出個交易的sighash是0x20就會不通過钮莲。

/src/script/interpreter.h 文件中有如下定義:

/** Signature hash types/flags */
enum {
    SIGHASH_ALL = 1,
    SIGHASH_NONE = 2,
    SIGHASH_SINGLE = 3,
    SIGHASH_FORKID = 0x40,
    SIGHASH_ANYONECANPAY = 0x80,
};
圖2.png

通過分析他們的測試用例免钻,我們可以猜想到:寫這個程序時之前假設了sighashtype的范圍是0~0x1f, 但現(xiàn)在實際現(xiàn)在可能出現(xiàn)的是0~0xff崔拥, 有可能是后來情況擴展了极舔。基于前一個假設時链瓦,像判斷一個sig hash的基本類型拆魏, 之前是用的sighash & 0x1f。但是如果一個sighash是0x21時會被判定為是SIGHASH_ALL慈俯,可以猜想到這個地方只想過濾出0x01, 0x02, 0x03這三種情況渤刃。

從二進制的層次我們繼續(xù)分析:0x1f = 0b00011111、0x21 = 0b00100001肥卡、0x3f = 0b00111111溪掀。右邊數(shù)第6位&0x1f每次都會是0,如果左邊的3位無效了步鉴, 實際應該是被過濾掉的揪胃。同理0x20的sig hash也會有問題璃哟。在0.17.0 版本時,校驗位是 0x1f喊递,在 0.17.1 版本更新為 0x3f随闪,以前0x21 & 0x1f = 1, 0x01 & 0x1f也是1。但改成3f骚勘, 0x21 & 0x3f就不在有效范圍內(nèi)了铐伴, 被過濾掉了。所以 0.17.1 這個版本主要修復了0x20的問題俏讹。

abc team對此漏洞的處理

在分析了漏洞和可能的響應后当宴, Bitcoin-ABC 開發(fā)人員為此漏洞準備了一個補丁,并發(fā)布了一個私有版本泽疆,以便直接分發(fā)給礦池運營商户矢。 由于挖礦社區(qū)的分散性,不可能直接與每個人取得聯(lián)系殉疼。 提供此版本是為了驗證Bitcoin Cash礦工在升級后轉發(fā)給值得信賴的礦工梯浪。

我們建議任何比特幣ABC 0.17.0用戶盡快升級到最新版本。

致謝

冰山瓢娜,隸屬 Meowww Security挂洛,比特大陸安全風控技術負責人。
余弦眠砾,慢霧科技聯(lián)合創(chuàng)始人虏劲。


本文由比特大陸風控部&慢霧科技聯(lián)合編寫!


家境清寒荠藤,整理不易伙单。

image.png
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市哈肖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌念秧,老刑警劉巖淤井,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異摊趾,居然都是意外死亡币狠,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門砾层,熙熙樓的掌柜王于貴愁眉苦臉地迎上來漩绵,“玉大人,你說我怎么就攤上這事肛炮≈雇拢” “怎么了宝踪?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長碍扔。 經(jīng)常有香客問我瘩燥,道長,這世上最難降的妖魔是什么不同? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任厉膀,我火速辦了婚禮,結果婚禮上二拐,老公的妹妹穿的比我還像新娘服鹅。我一直安慰自己,他們只是感情好百新,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布菱魔。 她就那樣靜靜地躺著,像睡著了一般吟孙。 火紅的嫁衣襯著肌膚如雪澜倦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天杰妓,我揣著相機與錄音藻治,去河邊找鬼。 笑死巷挥,一個胖子當著我的面吹牛桩卵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播倍宾,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼雏节,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了高职?” 一聲冷哼從身側響起钩乍,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎怔锌,沒想到半個月后寥粹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡埃元,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年涝涤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片岛杀。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡阔拳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出类嗤,到底是詐尸還是另有隱情糊肠,我是刑警寧澤辨宠,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站罪针,受9級特大地震影響彭羹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜泪酱,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一派殷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧墓阀,春花似錦毡惜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至勿锅,卻和暖如春帕膜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背溢十。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工垮刹, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人张弛。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓荒典,卻偏偏與公主長得像,于是被迫代替她去往敵國和親吞鸭。 傳聞我的和親對象是個殘疾皇子寺董,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355

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