从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

欧易(OKX)交易所

新用户永久最高20%手续费减免!

官网注册   APP下载

很多人都会担心,我的比特币会不会被盗,怎么样才能让我的比特币不被盗走,今天要和大家说的是比特币漏洞CVE-2010-5141.这个漏洞可以导致攻击者盗取任何人的比特币,危害十分严重。万幸的是该漏洞并没有被利用过,而且修复速度极快。该漏洞与比特币的脚本引擎有关,对公链开发者具有参考意义;从当下市场上的

我们在看UTXO模型之前先说说常见的账户模型,什么是账户模型?账户模型的数据结构简单可以理解为“账号=>余额”,每个账号都对应一个余额。举个例子:若账号A向账号B转账200.在账户模型中完成这个转账操作只需要A-200然后B+200;目前大部分软件都采用的是账户模型,比如银行系统、以太坊等等。

而比特币却使用了自行研发的UTXO模型,UTXO中是没有“账号=>余额”这样的数据结构的,那怎么进行转账?

Ⅱ、比特币如何操作转账

以上面A向B转账为例,在UTXO中完成这个转账需要以下操作:

1.找到A账号下200余额的来源,也就是意味着要找到A收款200的这笔交易x

2.以x交易为输入,以向B转账200的交易y为输出,x与y对应且x与y的转账金额必须相等

3.x交易被标记为已花费,y交易被标记为未花费

两笔交易的转账金额必须相等,简单解释就是收到多少就只能转出多少,实际上确实是这样。

但是又必须只给别人转一部分的时候怎么办?答案是只向他人转一部分,然后剩下的一部分转给自己另外一个号。

Ⅲ、引用两张来自网络的图文:

账户模型

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

UTXO模型

在本文当中比特币为什么采用UTXO模型不是重点,我们了解UTXO的原理即可。

二、比特币的脚本引擎

比特币脚本是非图灵完备的。比特币使用自行定义的一种脚本进行交易和其他的操作,为比特币提供有限的灵活性。实现诸如多重签名、冻结资金等简单功能,但更多的就不行了。

比特币这么做的原因是牺牲一定的完备性来保障安全性。比特币脚本的原理是先定义了一堆操作码,然后脚本引擎基于堆栈来逐个执行每个操作码。

堆栈很好理解,队列是先进后出,而堆栈正好相反,是先进先出,将一个元素压入(push)堆栈后该元素会被最先弹出(pop)。

在比特币早期的版本中发送一笔标准转账(pay-to-pubkey)交易需要脚本签名(scriptSig)和公钥验证脚本(scriptPubKey),具体处理流程如下:

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

先填入要执行的脚本(Script),然后签名(sig)和公钥(pubKey)被压入堆栈,然后操作码OP_CHECKSIG会去验证签名等,若验证通过就将true压入堆栈,否则就将false压入堆栈。

三、CVE-2010-5141漏洞分析

了解以上知识后就可以开始分析CVE-2010-5141漏洞了。笔者下载了存在漏洞的版本0.3.3.下载地址在github的bitcoin仓库中找release.

script.cpp代码片段VerifySignature函数:

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

执行每个交易都会调用VerifySignature函数,该函数用于执行脚本以及验证签名,然后给交易标注是否被花费。

首先txFrom参数是上一笔交易,txTo是正在处理的这笔交易,如果理解了上面的章节中讲解过的UTXO模型,这里就不难理解了。重点看1125行代码,调用了EvalScript函数,第一个参数是txin.scriptSig(包含签名信息)+分隔操作码OP_CODESEPARATOR+txout.scriptPunKey(包含公钥信息、OP_CHECKSIG指令),这些就是EvalScript函数要执行的脚本,后面的参数可以暂时不用管,只要EvalScript函数返回true那么这笔验证签名就通过了。EvalScript函数如何才能返回true?

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

智能合约在区块链上运作目前面临的问题?

智能合约在区块链上运作目前面临的问题?不论区块链技术的最终结局会是如何,在区块链上所运行的智能合约都需要大量的技术支持。在区块链的技术浪潮中,,一些辅助技术正处于悄无声息的研发当中,它们将对区块链技术的扩张产生至关重要的意义。

首先堆栈不能是空的,然后栈顶强转bool后必须是true。笔者简单解读为必须要有栈顶而且值不能是0.

然后再看关键的OP_CHECKSIG操作码

(注:由于操作码太多,本文针对OP_CHECKSIG操作码)

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

上面代码不难理解,调用Checksig函数来验证签名,然后返回给FSuccess变量,如果为真就压一个vchTrue(非0)进栈,否则就压一个vchFalse(0)进栈;如果opcode是OP_CHECKSIGVERIFY而不是OP_CHECKSIG的话就让vchTrue出栈,并开始执行后面的操作码。

按照OP_CHECKSIG的正常逻辑,验证签名不成功的话一定会有一个vchFalse留在栈顶,虽然堆栈不为空,但是栈顶的值是0.还是会返回false。

回到之前的代码,EvalScript函数执行的脚本主要由以下变量组成:

1.txin.scriptSig

2.OP_CODESEPARATOR

3.txout.scriptPubKey

第一个签名信息可控,第二个不用管只是一个分割符,会被删掉,第三个不可控,因为是来自上一个交易。

第一个变量可控,而且是作为脚本执行,所以这个变量可以不仅仅是签名信息,还能是opcode,这就好办了,下面需要引用一个神奇的操作码OP_PUSHDATA4.我们看看比特币0.3.3是怎么处理这个操作码的:

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

首先获取操作码。如果操作码的值小于或者等于OP_PUSHDATA4的值就把vchPushValue全压入堆栈,再跟进GetOp函数

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

经翻阅源码,发现OP_PUSHDATA4指令被定义为78.所以当函数遇到OP_PUSHDATA4时,指针会向又移78+4=82位,其中78位数据会被压入栈,所以只要在txin.scriptSig中注入一个OP_PUSHDATA4操作码,后面的公钥信息以及OP_CHECKSIG指令都会被”吃掉”并作为参数入栈,当指针走到最后时,进行最后的判断:

1.堆栈是否为空?不是

2.栈顶元素是否为0?不是

于是满足条件EvalScript函数返回true,然后VerifySignature函数也返回true,既然签名验证都绕过了,那别人的比特币便可以任意花费了。

四、CVE-2010-5141漏洞修复方案

笔者下载了比特币版本0.3.8.直接看关键部分代码

从比特币盗币漏洞浅析你的比特币怎么才能不被盗!

修复方案也很明确,把scriptSig和scriptPubkey分开执行,无论你scriptSig里面有什么也不会影响到后面的scriptPubkey执行。

写在最后:

因为比特币漏洞分析是从DVP第一期漏洞专题开始连载的,目前素材来自2010年,目前漏洞分析主要存在以下难点:

1.漏洞相关资料非常少,大多数漏洞都只有一个CVE编号和简介,不查阅大量资料无从入手。

2.环境搭建难,难在编译、私链搭建(早期的比特币甚至没有私链这个概念)等,比特币早期的源码编译需要的依赖现在很多都已经不维护并下线了。

基于这些原因,所以笔者仅做了理论研究,并未进行实践验证,如有错误之处还请指正。

另外要保证你的比特币安全,钱包的安全非常重要,就好比你的钱,现在银行不能为你来承担黑客攻击的风险,你只有自己准备一个安全的保险箱来确保你的比特币不被偷走,这也许也是去中心化的一个特征。

paxful是什么?paxful比特币场外交易平台介绍

Paxful交易平台是领先的对等市场,在这里普通人可以立即购买比特币,大家可以利用它搬砖或套现。Paxful的宗旨就是为劳动人民提供一个便捷、公平且安全的交易平台来兑换他们的劳动价值。通常我们最大的问题总是与钱本身,赚钱,花钱息息相关。通过创建一个全球化的未来平等支付平台,我们致力于开发人民大众的能

原创文章,作者:菜鸡,如若转载,请注明出处:https://www.20on.com/208372.html

(0)
菜鸡菜鸡
上一篇 24 10 月, 2022 2:15 下午
下一篇 24 10 月, 2022 2:15 下午

欧易(OKX)交易所

新用户永久最高20%手续费减免!

官网注册   APP下载

相关推荐

  • 区块链中Play to Earn是什么意思?一文读懂Play to Earn

    全文导读 不知道大家最近有没有听说过Play to Earn这一概念,它的简称为P2E,其实它就是当前的去亏啊连游戏行业中的一种非常火爆的商业模式,与之对应的还有一个概念,那就是F2P,即Free to Pay。Play to Earn这一模式可以说是正在

    27 4 月, 2022
  • USDT增发和币价有关系吗?泰达币增发影响深度分析

    全文导读 在了解USDT增发和币价有关系吗这一关系之前,币圈子小编想要先带大家的了解一下USDT的发行机制。简单的来说USDT与USD是以1:1的比例来保持锚定的,可以说每一枚USDT的背后都对应着一美元。所以如果USDT增发1亿美金

    30 3 月, 2022
  • SOL币怎么买?安全交易所推荐

    SOL币怎么买?安全交易所推荐 SOL币是一种新兴的加密货币,它具有可靠的安全性和可靠的去中心化特性,使其成为一种受欢迎的投资工具。由于其独特的特性,SOL币已经被许多投资者所接受…

    28 2 月, 2023
  • 火币DeFi项目有哪些?火币DeFi项目TOP10盘点

    全文导读 2020年的DeFi大热可以说是创造了无数的财富神话,很多投资者都被吸引,加入了质押挖矿的行列,一直到现在,DeFi板块依旧是币圈比较热门的项目板块。火币网,想必大家都知道,它是币圈中的头部交易所,也是三大交易所之一

    12 4 月, 2022
  • 币币交易是什么意思?币币交易新手入门教程

    全文导读 随着市面上数字货币的增加,传统的法定货币对数字货币交易已经不能满足全球投资者的投资需求,更多专业投资者开始尝试币币交易。那么,什么是币币交易呢?新手又如何进行币币交易?这都成了投资者想要了解的问题

    28 4 月, 2022
  • 比特币场外交易银行账户被冻结怎么办?附上解决办法

    摘要:本文将介绍比特币场外交易账户被冻的情况,以及如何解决这一问题。比特币作为一种去中心化的加密数字货币,需要场外交易账户来完成交易,但有时会出现账户被冻结的情况,导致无法进行交易…

    4 5 月, 2023
  • RUNE是什么币种?RUNE币前景和价值深度分析

    全文导读 说起RUNE币,不知道大家的了解有多少。根据最新的行情数据显示,截止到2021年11月4日14:46,RUNE币的价格是7.8848美元,今日涨幅为+2.11%,24h成交额是1.02亿美元。RUNE当前流通市值为17.69亿美元,在加密货币市

    10 4 月, 2022
  • 怎样用小狐狸钱包配置OKExChain测试网?

    怎样用小狐狸钱包配置OKExChain测试网? 下载小狐狸钱包(安卓版),并创建钱包:https://www.jb51.net/blockchain/797222.html 1,怎…

    13 12 月, 2022
  • 派币是真的吗?PI币究竟是真的假的?

    摘要: 近年来,PI币成为热门话题,而有人对其真实性质产生疑虑:是一场骗局还是一种革命?本文将从四个方面阐述PI币是骗局,解析PI币真相,引出读者的兴趣,并提供有关背景信息。 一、…

    14 4 月, 2023
  • filecoin是什么[filecoin是什么项目]

    摘要: Filecoin是一个去中心化的存储网络项目,旨在通过将空闲存储空间转化为加密货币来改变传统的云存储模式。它由一组经验丰富的开发者和研究人员创建,得到了VC投资界和加密社区…

    21 6 月, 2023