博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BCH 挖矿程序 Bitcoin-ABC 分叉漏洞剖析
阅读量:6831 次
发布时间:2019-06-26

本文共 1240 字,大约阅读时间需要 4 分钟。

作者 慢雾安全团队 背景

Bitcoin-ABC 官方网站在 5 月 7 日发文称:

Bitcoin-ABC 开发团队在 4 月 26 日得到匿名人士报告,比特现金矿工使用的 Bitcoin-ABC 0.17.0 及以下版本客户端存在一个严重漏洞。开发团队对漏洞进行分析后,更新了补丁并发布客户端 0.17.1 版本并把软件发给了 BCH 矿池。

漏洞分析

慢雾安全团队通过分析 Bitcoin-ABC commit 修复代码(https://reviews.bitcoinabc.org/D1313)得出结论:

BCH 挖矿程序 Bitcoin-ABC 分叉漏洞剖析

在 src/script/sighashtype.h 文件第 70 行开始,官方修改了函数名并对 baseType 参数值进行了调整,由 BaseSigHashType(sigHash & 0x1f) 更新为 BaseSigHashType(sigHash & ~(SIGHASH_FORKID | SIGHASH_ANYONECANPAY))。

BCH 挖矿程序 Bitcoin-ABC 分叉漏洞剖析

在 src/script/sighashtype.h 头文件里定义了常量 SIGHASH_FORKID 和 SIGHASH_ANYONECANPAY 的值为 0x40 和 0x80。

所以 ~(SIGHASH_FORKID | SIGHASH_ANYONECANPAY) 结果是 0x3f。

假设 sigHash 是 0x21,换算成二进制:0x1f = 0b00011111、0x21 = 0b00100001、0x3f = 0b00111111。

0.17.0 版本时,校验位是 0x1f,在 0.17.1 版本更新为 0x3f。baseType 计算过程 0x21 & 0x1f = 1, 0x01 & 0x1f 也是 1;在 0.17.1 版本校验位更新为 0x3f 后,baseType 为 0x21 & 0x3f = 21,就不在有效范围内而被过滤掉,所以修复了 0x20 的问题。

漏洞影响

据 Bitcoin-ABC 开发者透露,这个漏洞可以在无意中引发比特现金网络分叉。攻击者可以构建一笔恶意的交易,这笔交易可以被 Bitcoin-ABC 0.17.0 及以下版本的矿工接受并打包到区块中。但是,其他兼容比特现金的挖矿应用例如 Bitcoin Unlimited 客户端会拒绝接受这个区块。

“BUCash 和 Bitcoin-ABC 客户端 0.17.0 以前的版本都可能从主链上分裂出去 —— 分析漏洞时只包括 Bitcoin-ABC 和 BUCash 节点。”开发团队介绍说道。

“Bitcoin ABC 处理问题非常专业和负责——他们迅速修复了漏洞并(把软件)私下发给了矿工,从而降低了区块链分叉的风险。” Bitcoin.com 矿池的首席执行官 Shaun Chong 说道。

转载地址:http://pnnkl.baihongyu.com/

你可能感兴趣的文章
Codeforces 894B - Ralph And His Magic Field
查看>>
利用C语言中的函数指针实现c++中的虚函数
查看>>
【python网络编程】新浪爬虫:关键词搜索爬取微博数据
查看>>
python 多线程就这么简单(转)
查看>>
最高的情商,就是满怀感恩去工作
查看>>
Mybatis异常总结
查看>>
图论 --- 三维空间bfs
查看>>
dp - Codeforces Round #313 (Div. 1) C. Gerald and Giant Chess
查看>>
day5 列表
查看>>
控件里的字体下划线
查看>>
[转载] 深入浅出工厂模式
查看>>
hdu 2642 Stars
查看>>
MySQL学习(一) 概述
查看>>
WEB新手之do u know caidao?
查看>>
Generic Access Profile
查看>>
py 的 第 15 天
查看>>
Asp.net Mvc Action重定向总结
查看>>
菜单下拉条
查看>>
set 赋值(转载)
查看>>
转:Chrome渲染分析之Timeline工具的使用
查看>>