Brahma TopGear惨遭攻击 竟是因为囫囵吞枣不够用户死活的函数授权问题
前言
2022年11月10日,知道创宇区块链安全实验室监测到ETH 链上的 brahTOPG 项目遭到攻击。黑客经过研究发现该项目存在任意外部调用的漏洞,原因是该项目的Zapper合约未对用户传入的数据进行严格检查,因此攻击者利用此漏洞窃取对合约有授权用户的代币,从中获利约9万美元。
事件分析
通过分析攻击的Txn
0xeaef2831d4d6bca04e4e9035613be637ae3b0034977673c1c2f10903926f29c0:

攻击者查看了0x392472c4369d6cdea89e2bddfd8144eecfdc032c钱包余额,然后调用Zapper合约的zapIn() 函数:

该函数会为合约转账 requiredToken 指定的代币,由于该函数传入的参数外部可控,攻击者构造该参数为假代币,并将假代币转给 Zapper 合约,接着会调用内部函数zap():

假代币就会进到变量 inputToken 里,随后检查合约中假代币的余额是否大于或等于传入的值,由于IERC20(inputToken).approve()函数会外部调用假代币合约的 approve() 函数,最后外部调用了 swapTarget() 函数,该函数的传入参数同样外部可以操控,导致之后攻击者利用此任意外部调用漏洞,转走其他有授权用户的 USDC 代币:


攻击者重复以上步骤攻击了三次,转移了受害者账户下约889343枚 USDC 代币。
总结
此次被攻击的主要原因在于Zapper合约没有对用户上传数据进行严格检查监控,导致了任意外部调用的问题,然后攻击者利用此任意外部调用问题窃取了对合约有授权的用户代币。
合约函数权限的检查仍是容易被忽略的,黑客恰好可以利用该问题,进行任意外部调用,从而发生安全事件。
郑重声明:本文版权归原作者所有,转载文章仅为传播信息之目的,不构成任何投资建议,如有侵权行为,请第一时间联络我们修改或删除,多谢。
狗狗币价格展望:10亿美元资金涌入后的DOGE能否触及10美元大关?
狗狗币(DOGE)当前正处于积极的上涨轨道上,其价格稳固于0.1381美元附近,并在盘中一度触及0...
BNB Chain 的 meme Summer$FOUR传承 CZ “4” 文化
自 2023 年开始,一张Binance首席执行官赵长鹏 ( CZ ) 经常在其推特账号上发手比“...
币安发钱了 BNB HODLer 空投首发「Banana Gun」 币价飙升创新高
今日凌晨,币安宣布了第一期HODLer 空投的代币为BANANA,其是Banana Gun 机器人...