快捷搜索:  网络  后门  CVE  渗透  木马  扫描  黑客  as

AMR智能合约漏洞阐发

0×00 项目简述

A妹妹br首要目标是打造具有高度弹性且易于连接的分布式宽带接入平台,同时降低上彀相干成本。A妹妹br打算创建具有人工智能以及智能合约功能的高通量区块链平台,在为无线宽带用户清除停滞的同时,确保无数接入基础架构所有者公平参与。自2017年9月1日起发售AMMBR代币。

0×01 漏洞详情

合约地址:

0x96c833e43488c986676e9f6b3b8781812629bbb5

合约代码地址:

https://etherscan.io/address/0x96c833e43488c986676e9f6b3b8781812629bbb5#code

合约类型:ERC20(https://github.com/ethereum/EIPs/issues/20)

漏洞函数:multiTransfer

漏洞类型:整数溢出

漏洞风险:可导致增发任意数额的AMR代币至任意以太坊账户。

0×02 细节阐发

image.png

代码201行在处理输入参数tokens数组累加的时辰,没有使用SafeMath,企业黑客,使得攻击者有机会组织一次整数溢出,导致后续计算totalTokensToTransfer时值可以被攻击者篡改,终极导致绕过204行余额检查,转出巨额资产。

整数溢出的道理无比简单,道理如图所示,要是两个8位变量A以及B按位相乘,效果越过8位,越过位将被丢弃,只保留后8位长度。该漏洞中的产生溢出的变量名为totalTokensToTransfer,该变量类型为uint,在Solidity中,uint长度为256位,所以只需累加超过2^256-1大小的数,将会导致整数溢出。

image.png

0×03 调试与POC

我们使用Remix调试代码,起首调用mint函数为本人的账户增添一点Token余额,这个函数必须合约创建者才能调用,为本人增添余额后。我们直接调用multiTransfer来触发漏洞。

POC以下:

["0xda12391a57b16510ac82384640a44ecbd43243db","0xca35b7d915458ef540ade6068dfe2f44e8fa733c","0x14723a09acff6d2a60dcdf7aa4aff308fddc160c"],["38597363079105398474523661669562635951089994888546854679819194669304376546645","38597363079105398474523661669562635951089994888546854679819194669304376546645","38597363079105398474523661669562635951089994888546854679819194669304376546646"]

参数1我们随便创建了三个地址,该地址用来接收被黑资产。tokens参数使用的值38597363079105398474523661669562635951089994888546854679819194669304376546645,为2^256/3计算得出,由于不能整除,我们在最后一个参数加一,使得终极totalTokensToTransfer累加可等于2^256。由于uint256最大可容纳值为2^256-1,累加等于2^256使得totalTokensToTransfer被溢出越过1位,导致该数被攻击者置零。

点底部的Debug可以看到漏洞细节。我们可以看到走到这里totalTokensToTransfer变量由于整数溢出已经被冲成零。

image.png

image.png

然后继续往下走,走至return处,可以我们参数中的三个账户被充入了指定数额的资产。

image.png

0×04修复建议

将201利用用SafeMath改成:

totalTokensToTransfer =totalTokensToTransfer.add(tokens[i]);

*文章作者莫良@BYSEC.IO,

您可能还会对下面的文章感兴趣: