木星链 木星链
Ctrl+D收藏木星链

以太坊:从一道CTF题折射出的智能合约安全问题

作者:

时间:1900/1/1 0:00:00

belluminarbank是俄罗斯战队在WCTF上出的一道EVM题目,其中用到了很多ETH中经典的漏洞。虽然难度都不是很大,但是如果对EVM相关特性不了解的话还是有一定难度的,我们就来介绍一下ETH智能合约中的安全问题。

这道题的题目是一个存储交易类合约,用户可以通过给合约发送ether实现将ether存储在合约中的目的。攻击者的目标就是将存储在这个合约里的所有ether全部取走。

我们不讲这个WCTF的题目,主要是了解智能合约中的安全问题有哪些,危害多大;

就以太坊智能合约的安全漏洞。新加坡国立大学的LoiLuu提出了现在的智能合约存在的几种安全漏洞。然而,由于智能合约目前还只是初级阶段,相信各种安全问题会不断的发现。

重入漏洞:

也被称为或与空竞争,递归调用漏洞,未知调用等。

ApeCoin DAO终极指南提案AIP-251获得通过:金色财经报道,据Snapshot投票数据显示,ApeCoin DAO新手入门终极指南提案AIP-251已经获得通过,该提案发起人BojangleGuy.Eth 在投票结束后发推文透露,该提案的通过率为93.28%。ApeCoin DAO终极指南类似于解决ApeCoin社区没有教学材料(例如视频内容、信息图表或现场培训)导致社区活跃度和参与度低的问题,通过创建一个集中的、易于理解的信息来源来解决社区的基本问题。[2023/6/18 21:44:58]

菲尔戴安说过:这种漏洞在很多时候被很多不同的人忽略:审阅者倾向于一次一个地审查函数,并且假定保护子例程的调用将安全并按预期运行。

重入攻击介绍:

1.重入攻击,可能是最着名的以太坊漏洞;第一次被发现时,每个人都感到惊讶。

Gabor Gurbacs:监管机构不应该在未来推动银行对数字资产进行托管:金色财经报道,纽约投资管理公司VanEck数字资产战略总监Gabor Gurbacs在社交媒体上表示,FDIC查封了硅谷银行并控制了其存款。监管机构不应该在未来推动银行对数字资产的托管。数千亿美元的银行破产,并在几天内摇摆10-30%以上,这不会激发人们对系统的信心。

银行业正面临着沉重的压力,这是一个关键的时刻。人们和企业可能会越来越多地、迅速地将银行风险转移到短期限、低杠杆、低期限的资产支持的美元稳定币、黄金稳定币和比特币。特别是加密货币投资者。[2023/3/11 12:55:23]

2.它在数百万美元的抢劫案中首次亮相,导致了以太坊的分叉。

3.当初始执行完成之前,外部合同调用被允许对调用合同进行新的调用时,就会发生重新进入。

4.对于函数来说,这意味着合同状态可能会在执行过程中因为调用不可信合同或使用具有外部地址的低级函数而发生变化。

新加坡金管局:将对加密行业不良行为采取“强硬措施”:6月23日消息,新加坡金管局首席金融科技官Sopnendu Mohanty表示,新加坡将对加密行业的不良行为采取“残酷无情的强硬措施”,这一言论似乎显示,该国在保持多年的加密友好态度后,其立场发生了明显转变。Mohanty对私人加密货币的价值提出了质疑,并表示他预计政府支持的替代品将在三年内推出。(Financial Review)[2022/6/23 1:26:14]

在以太坊中,当一个合约调用另一个合约的时候,当前的操作就要等到调用结束之后才会继续。这时,如果被调用者需要使用调用者当前所处的状态,那么这就产生了问题。

著名的DAO攻击事件就是因为这个漏洞而发生的。

示例:

1.个聪明的合同跟踪些外部地址的平衡,并允许户通过其公共资检索withdraw()功能。

推特董事会一致建议股东投票通过马斯克并购协议:6月21日消息,推特为马斯克收购交易特别会议提交代理声明,推特公司称,董事会一致建议股东投票通过并购协议。(金十)[2022/6/21 4:43:20]

2.个恶意的智能合同使withdraw()函数检索其全部余额。

3.在更新恶意合同的余额之前,受害者合同执call.value(amount)()低级别函数将以太发送给恶意合同。

4.该恶意合同有个付fallback()接受资的功能,然后回调到受害者合同的withdraw()功能。

5.第次执会触发资转移:请记住,恶意合同的余额尚未从次提款中更新。结果,恶意合同第次成功退出了全部余额。

以下函数包含易受重攻击影响的函数。当低级别call()函数向msg.sender地址发送ether时,它变得易受攻击;如果地址是智能合约,则付款将触发其备功能以及剩余的交易体:

交易顺序依赖合约:

交易顺序依赖就是智能合约的执行随着当前交易处理的顺序不同而产生差异。例如,有两个交易T和T,两个区块链状态S和S,并且S状态处理完交易T后才能转化为状态S。那么,如果矿工先处理交易T,交易T调用的就是S状态下的智能合约;如果矿工先处理交易T再处理交易T,那么由于先执行的是T,合约状态就转化为S,最终交易T执行的就是状态S时的智能合约。

攻击方法举例:

攻击者提交一个有奖竞猜合约,让用户找出这个问题的解,并允诺给予丰厚的奖励。攻击者提交完合约后就持续监听网络,如果有人提交了答案的解,此时提交答案的交易还未确认,那么攻击者就马上发起一个交易降低奖金的数额使之无限接近0。当矿工处理这两个交易时,当前交易池就有两个待确认交易:一个交易是提交答案,一个交易是更改奖金数额。如果矿工先处理的是敌手更改奖金的交易,而敌手可以通过增加交易费用让矿工先处理自己的交易,那么等到矿工处理提交答案的交易时,答案提交者所获得的奖励将变得极低,敌手就能几乎免费的获得正确答案。

时间戳依赖合约,也称时间篡改;

矿工处理一个新的区块时,如果新的区块的时间戳大于上一个区块,并且时间戳之差小于900秒,那么这个新区块的时间戳就是合法的。这是以太坊协议所规定的。时间戳依赖顾名思义就是指智能合约的执行依赖当前区块的时间戳,随着时间戳的不同,合约的执行结果也有差别。

攻击方法举例:

1.一场比赛在今天午夜付出了第一名球员。

2.恶意矿工包括他或她试图赢得赛并将时间戳设置为午夜。

3.在午夜之前,矿工最终挖掘该块。当前的实时时间“能够接近”到午夜,络上的其他节点决定接受该块。

以下功能只接受特定期之后的呼叫。由于矿可以影响他们区块的时间戳,他们可以尝试挖掘个包含他们交易的区块,并在未来设定个区块时间戳。如果够接近,它将在网络上被接受,交易将在任何其他玩家试图赢得比赛之前给予矿工以太:

误操作异常:

在以太坊中,一个合约调用另一个合约可以通过send指令或直接调用另一个合约的函数。然而在调用过程中可能会出现错误,调用的合约就会回退到之前的状态。那么这个异常就可能无法很好地被调用者获知,这取决于调用方式。例如,通过send指令调用的合约应该通过检查返回值来验证合约是否被正确执行。

攻击方法举例:

有个名KingOfTheEtherThrone的智能合约:用户可以通过一定数量的以太币成为“以太币国王”,支付的数额由现任国王决定。很显然,当前国王可以通过买卖国王获得利润。当一个用户声称为国王后,合约就发送赔偿金给现任国王,并指定这个用户为新的国王。然而,这个合约并没有检查支付赔偿金的交易的结果。这样一旦合约在执行过程中产生了异常,现任国王就有可能同时失去王座和赔偿金。

可能的攻击方式就是敌手故意超出调用栈的大小限制。以太坊虚拟机规定调用栈的深度为1024。敌手在攻击之前,首先调用自身1023次,然后发送交易给KoET合约,这样就造成了合约的调用栈超出了限制,从而出现了错误。合约出错后,因为这个合约没有检查合约的返回值,那么如果合约在发送赔偿金给现任国王的过程中出现了异常,那么现任国王极有可能失去王座和赔偿金。

标签:以太坊ETHWCT以太坊币是什么币ETH钱包地址ETH挖矿app下载Etherael指什么寓意WCT币是什么币

币赢交易所热门资讯
比特币:这个国家1000亿只能买个面包,最大面值100万亿,却吃不上饭!

小编经常想着手里要是有个几千万上亿的话,不用工作了,然后去各个国家旅游,买各种豪车,豪华住宅等等,但是当你来到这个国家,你就不会这样想了,手里抓着几千万上亿不知道能买点什么.

1900/1/1 0:00:00
GHT:一部币圈“惨”痛录

~《币圈悲情马奇诺》~ 自从比特币被爆炒之后,由国内外领先团队生产形形虚拟货币也竞相亮相币圈大炒锅,都想成为圈内外人士,投资机构追捧的宠儿,成为币种投资餐桌的一道名角.

1900/1/1 0:00:00
MAS:晚上翻来覆去睡不着?送给晚睡强迫症患者的自救手册

连续11天不睡觉,身体会怎样?1965年,一名17岁的美国高中生亲身试验,结果令人大吃一惊。试验第二天,他的眼睛停止了聚焦,随后丧失了通过触摸鉴别事物的能力;第三天,他变得焦躁、笨拙;实验结束时.

1900/1/1 0:00:00
区块链:火币李林6亿收购港股公司 首家虚拟币交易所上市?

来源:壹块硬币 8月27日晚,区块链及币圈传来重磅消息!平均每股2.27元,总计耗资6亿港币,火币创始人李林收购桐成控股73.73%股份,成为一家港股上市公司的实际控制人.

1900/1/1 0:00:00
区块链:青岛举行点钞技能比赛 点钞员半小时最快能点千余元零币

2018年11月14日,青岛,为了检验点钞员清点零币速度、准确率、票面整洁性等方面技能,温馨巴士开展点钞员点钞技能比赛.

1900/1/1 0:00:00
区块链:周榜 | 全球Token涨跌幅Top20

按照惯例,UP统计了本周涨幅榜Top20,以及跌幅榜Top20。自5月以来,比特币价格一直都处于震荡下跌的趋势,整个市场也阴霾密布,但近期市场似乎已经拨开了阴霾.

1900/1/1 0:00:00