火星链 火星链
Ctrl+D收藏火星链
首页 > 狗狗币 > 正文

RES:深入理解「拒绝服务」漏洞

作者:

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

1.前言

拒绝服务(DoS):DoS是DenialofService的简称,即拒绝服务,任何对服务的干涉,使得其可用性降低或者失去可用性均称为拒绝服务。简单的理解就是,用户所需要的正常服务请求无法被系统处理。例如一个计算机系统崩溃或其带宽耗尽或其硬盘被填满,导致其不能提供正常的服务,就构成拒绝服务。拒绝服务攻击:造成DoS的攻击行为被称为DoS攻击,其目的是使计算机或网络无法提供正常的服务。在互联网中,拒绝服务攻击大致可以分为三类:利用软件实现上的缺陷;利用协议上的漏洞;利用资源压制。而在区块链中,拒绝服务攻击扰乱、中止、冻结正常合约的执行,甚至合约本身的逻辑无法正常运行。2.漏洞概述

在Solidity里,拒绝服务漏洞可以简单的理解为「不可恢复的恶意操作或者可控制的无限资源消耗」,也就是对以太坊合约进行DoS攻击,这就可能导致Ether和Gas的大量消耗,更严重的是让原本的合约代码逻辑无法正常运行。举个例子,超市有三个收银点,正常来说人们排队在收银点进行扫码支付,但是有一天网络出现了问题,所有收银点的顾客扫码支付都失败了,而后面的人也不能进行支付买单,就导致了收银点的堵塞,超市不能正常运营。又或者,在支付时有顾客故意闹事,使得后面的顾客也不能去支付,这同样也会导致超市不能运营。我们可以看到有来自内部的,还有来自外部的,都是可能会造成拒绝服务攻击。在智能合约中也是一样的,攻击者通过消耗合约的资源,让用户短暂地退出不可以操作的合约,严重时甚至能永久地退出,从而把以太币锁在被攻击的合约中。3.漏洞分析

全国政协委员刘尚希:激励推动银行在区块链等领域深入合作:全国政协委员、中国财政科学研究院院长刘尚希建议,在政策上支持开放银行构建,激励银行业善用我国金融科技领先和更本土化的优势,快速发展技术能力:发展线上服务能力和数字风控技术,实现线上线下业务融合;大力推动银行业部署下一代分布式金融信息系统,建设性能稳定、智能化运营的开放式系统架构,为开放银行建好硬件底座;激励推动银行在人工智能、区块链等核心关键技术领域进行深入合作。(中国经营报)[2020/5/23]

智能合约中的拒绝服务攻击一般有三种:在外部操纵映射或数组循环。所有者操作。基于外部调用的进展状态。3

}在上面的代码片段中我们可以看到,distribute()函数中会去遍历投资者数组,但是合约的循环遍历数组是可以被外部的人进行人为扩充,如果有攻击者要攻击这个合约,那么他可以创建多个账户加入投资者的数组,让investors的数据变得很大,大到让循环遍历数组所需的gas数量超过区块gas数量的上限,此时distribute()函数将无法正常操作,这样就会造成该合约的拒绝服务攻击。针对以上情况,合约不应该对可以被外部用户人为操纵的映射或循环数组进行批量操作,这里更建议使用取回模式而不是发送模式,即每个投资者可以通过使用withdrawFunds()取回自己应得的代币。如果合约必须需要通过遍历一个变长数组来进行转账,那么最好是估计完成它们大概需要多少个区块以及多少笔交易,从而限制数组长度,此外还必须能够追踪得到当前进行到哪以便当操作失败时从那里开始进行恢复。如下面的代码所示,必须确保在下一次执行payOut()之前另一些正在执行的交易不会发生任何错误。structPayee{addressaddr;uint256value;}Payeepayees;uint256nextPayeeIndex;functionpayOut(){uint256i=nextPayeeIndex;while(i<payees

声音 | 科蓝软件:公司与蚂蚁金服在区块链方面有广泛深入合作:科蓝软件(SZ300663)在互动平台表示,公司与蚂蚁金服在互联网银行的前台、中台、后台产品和项目以及区块链方面已经有广泛深入的合作,双方是战略层面的合作,并且还在继续深化以及向其他领域扩展,具体请参考公司相关公告。[2019/11/20]

nextPayeeIndex=i;}3

//...额外的一些ICO功能//重写transfer函数,先检查isFinalizedfunctiontransfer(address_to,uint_value)returns(bool){require(isFinalized);super

contractPOC{addressowner;AuctionauInstance;constructor()public{owner=msg

modifieronlyOwner(){require(owner==msg

functionsetInstance(addressaddr)publiconlyOwner{//指向原合约地址auInstance=Auction(addr);}functionattack()publiconlyOwner{auInstance

声音 | 中国平安:深入开展人工智能、区块链、云三大核心技术的研发与应用:中国平安(601318)昨日发布了即将在年度股东大会及H股类别股东大会上的决议资料,其中包括《公司2019-2021年发展规划》,规划在发展措施中指出,公司持续夯实基础,深入开展人工智能、区块链、云三大核心技术的研发与应用,深度赋能核心业务的客户经营、渠道管理、客户服务、风险管控等方面,推动业务价值提升和创新公司孵化。[2019/3/29]

function()externalpayable{revert();}}攻击者先通过攻击合约调用bid()函数向竞拍合约转账成为新的竞拍者currentLeader,然后新的bid()函数被执行进行竞标的时候,当执行到require(currentLeader

function()payable{//回退函数,使用revert报错revert();}}在Remix中进行调试查看结果,首先使用账户(0x5B38Da6a701c568545dCfcB03FcB875f56beddC4)设置初始竞争价格并部署漏洞合约代码PresidentOfCountry.sol。部署好后合约的地址为0xd9145CCE52D386f254917e481eB44e9943F39138,后面在部署攻击合约时需要用到。

声音 | 交通运输部副部长:积极参与区块链等贸易服务 更深入地参与国际竞争:据上证网消息,交通运输部副部长刘小明在2018全球贸易与国际物流高峰论坛上透露,要把创新能力建设摆到更加突出的战略地位,全力推进互联网+高效物流融合发展。坚持全面开放发展,推进物流领域开放向纵深发展。积极参与跨境电商、区块链等贸易服务,更深入地参与国际竞争。[2018/11/20]

点击president可以查看当前竞争者的地址。

使用账户(0x5B38Da6a701c568545dCfcB03FcB875f56beddC4)调用becomePresident并携带1eth,执行成功后再点击president查看,发现新的总统地址已经变成了0X5B的账户。

中国科技大学原党委书记郭传杰:要促进区块链等技术在教育领域的深入应用:5月30日,第四届“互联网+教育”创新周在北京闭幕。中国科技大学原党委书记郭传杰表示,要促进人工智能、云计算、大数据、区块链、物联网等技术在基础教育研究领域的深入应用,提升互联网和教育的深度融合及创新。[2018/6/2]

此时有一个攻击者(0xAb8483F64d9C6d1EcF9b849Ae677dD3315835cb2)编写了一个攻击者合约Attack.sol,携带2eth并设置_target为PresidentOfCountry合约地址(0xd9145CCE52D386f254917e481eB44e9943F39138)进行部署。

部署好后的攻击合约地址为0xa131AD247055FD2e2aA8b156A11bdEc81b9eAD95,此时再点击president进行查看新总统的地址,发现已经是攻击合约的地址了。

之后如果还有其他用户想来竞争总统位置,就需要大于2eth的价格去调用becomePresident函数,这里有个用户(0xCA35b7d915458EF540aDe6068dFe2F44E8fa733c)想去竞争总统,携带3eth去调用becomePresident,结果发现报错并回退,点击president发现总统地址还是攻击合约没,此时不管是谁使用多少的以太币去调用becomePresident,结果都是失败,该合约已经不能进行正常的操作,这就说明合约受到了拒绝服务攻击。

4.2真实案例

下列代码是实际合约中存在拒绝服务攻击的案例,只写了关键的代码并做了相关的改动。可以看到合约的关键代码是用作提款操作,但是在提款中有一个判断要提款的金额和用户在该合约中存款的数量是否相等,而并不是大于等于,那么就有可能发生当用户要提出amount数量的代币时,由于各种原因导致balances变动,甚至是用户不想全部提款,从而使得判断条件require(balances==amount);不成立,这时就会造成短暂的拒绝服务攻击。...functionwithdraw(uint256amount)public{//提款amount数量require(balances==amount);//检查要提款的金额是否等于该用户在合约中的存款balances-=amount;//修改合约中存款的状态变量msg.sender.transfer(amount);//转账到用户账户}而修改的办法就是将判断条件require(balances==amount);修改为require(balances>=amount);就可以了。4.3历史案例

在历史上,2016年2月6日至8日,在游戏KotET(KingogtheEtherThrone)的「TurbulentAge」期间,就遭受到了拒绝服务攻击,导致部分角色的补偿和未接收款项无法退回玩家的钱包中。同年6月,GovernMental合约也遭受到了拒绝服务攻击,当时1100个以太币通过使用250万个gas交易而获得,这笔交易超出了合约能负荷的gas上限,从而导致交易暂停。相关的还有Fomo3D等的拒绝服务攻击。5.解决办法

通过上面的讲解,我们可以发现拒绝服务攻击在智能合约中的影响也是非常严重的,所以针对拒绝服务攻击,合约开发者应该针对上面漏洞分析时讲到的三种情况进行相应的代码修改。比如对于外部操作的映射或者数组循环,需要对长度进行限制等;而对于所有者操作需要考虑合约的非唯一性,不要使得合约因为某个权限账户而导致整个业务瘫痪;基于外部调用的进展状态需要对函数的调用进行异常处理,一般来说内部函数的调用不会造成危害。如果调用失败也只是会进行回退,而外部调用具有不确定性,我们不知道外部调用者想干什么,如果被攻击者攻击,就可能会造成严重的后果,具体表现为恶意返回执行错误,造成正常代码无法执行,从而造成拒绝服务攻击,那么针对这种开发者就应该加入函数执行异常的处理机制。总的来说,合约开发者需要考虑合约代码的代码逻辑全面性和缜密性等,这样才能更好的杜绝拒绝服务攻击。6.参考文献

拒绝服务攻击_百度百科(baidu.com)以太坊智能合约安全入门了解一下(rickgray.me)《智能合约安全分析和审计指南》

标签:ENTRESPAYUNTAPY Centerares币最新行情PlasmaPayEncountr

狗狗币热门资讯
区块链:三分之一的美国摇摆州选民对加密友好,最先支持加密货币的政党或将大获全胜

观点来源:《新闻周刊》编译整理:白泽研究院最近,伦敦民意调查公司Redfield&WiltonStrategies为《新闻周刊》进行的一项独家民意调查显示.

1900/1/1 0:00:00
区块链:如何将具有炒作价值的 NFT 应用到新型共享经济的设计中?

作者|梁文辉出品|白话区块链前段时间,NFT因为奢侈品火了。为了纪念LV创始人,LV研发了一款手游Louisthegame,这款游戏的亮点是其中隐藏的30枚NFT.

1900/1/1 0:00:00
DOGG:传奇嘻哈说唱教父 Snoop Dogg 高调入局 NFT 领域,NFT成为后疫情时代的「新宠」

作者|三黎出品|白话区块链截至10月11日,NFT市场Opensea的交易总额突破85亿美元,不过数值屡创新高对于很多人而言已经快习以为常了,毕竟今年以来NFT作为艺术界和区块链的“新宠”.

1900/1/1 0:00:00
SERG:一文深入了解将比特币合法化后的乌克兰现状

编译整理|白泽研究院2021年9月10日,乌克兰将比特币合法化,明确了比特币在该国是合法资产。在该法案获得通过后,法院可以以此来保护个人和企业,因为它提供了税收的明确性,并正式允许比特币企业在国.

1900/1/1 0:00:00
BAN:一文了解 DAO 所需角色及从中获取报酬的不同方式

撰文:LucasCampbell本文编译自Bankless在过去十年中,工人阶级越来越多地转向兼职工作。随着分散的任务和零工经济的蓬勃发展,工人和雇主都意识到工作是模块化的.

1900/1/1 0:00:00
PUNKS:Nansen:解析 CryptoPunks 价值背后的基本驱动力

1CryptoPunks是什么?CryptoPunks是一个由1万个独特的可收集头像组成的集合,被广泛认为是当今CryptoArt运动的开始.

1900/1/1 0:00:00