ANC:老调重弹,ERC1155的重入攻击又“现身”,Revest Finance被攻击事件简析

2022年3月27日,成都链安链必应-区块链安全态势感知平台舆情监测显示,DeFi协议RevestFinance遭到黑客攻击,损失约12万美元。

据悉,RevestFinance是针对DeFi领域的staking的解决方案,用户通过RevestFinance参与任何DeFi的staking,都可以直接创建生成一个NFT。

PancakeSwap已销毁超850万枚CAKE,价值1300万美元:7月24日消息,PancakeSwap发推称,今日已销毁8,502,679枚CAKE,价值1300万美元。[2023/7/24 15:55:52]

在攻击发生之后,项目方官方发推表示他们以太坊合约遭受了攻击,目前已采取措施确保所有链中的剩余资金安全。

链借贷协议Pike Finance将上线Coinbase Layer2网络Base:6月15日消息,跨链借贷协议Pike Finance将在Coinbase Layer2网络Base上发布,它由跨链桥Wormhole和USDC发行商Circle提供支持,旨在在不牺牲安全性的情况下帮助用户摆脱原生链的限制,不需选择桥接和封装代币即可实现不同区块链之间的直接交互。[2023/6/15 21:38:57]

成都链安技术团队对此事件进行了相关简析。

数据:约1300万美元Nomad被盗资金被归还:8月4日消息,据欧科云链OKLink多链浏览器显示,被标记为“Nomad官方被盗资金回收”的链上地址,目前已收到包括146枚ETH、626万枚USDC、201万枚USDT、15万枚DAI、399枚WETH在内价值约1300万美元的资产。[2022/8/4 2:58:18]

该mintAddressLock函数用于查询并向目标铸造NFT,并且nextid会在铸造NFT后进行更新。

攻击者第一次调用mintAddressLock函数铸造了2个ID为1027的Token为后续攻击做准备,随后再次调用mintAddressLock铸造了3600个ID为1028的Token,在mint函数完成前攻击者重入了depositAdditionalToFNFT函数,由于NFTnextId在mint函数铸造NFT完成并通知后进行更新,此时的nextId仍然为1028,并且合约并未验证1028的Token数量是否为0,因此攻击者再次成功地铸造了1个ID为1031的Token,完成了攻击。

#2总结建议

此次攻击中的铸币相关函数未严格按照检查-生效-交互模式设计,且未考虑到ERC1155token转账重入的可能性。

建议在合约设计时严格按照检查-生效-交互模式设计,并在ERC1155token相关DeFi项目中加入防重入的功能。

截止目前为止,攻击者仍然未将资产进行转移,成都链安将持续进行监控。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:15ms0-0:642ms