“零元购” —— TreasureDAO NFT 交易市场漏洞分析

区块链安全 2年前 (2022) admin
588 0 0

By:九九@慢雾安全团队


2022 年 03 月 03 日,据慢雾区消息,TreasureDAO 的 NFT 交易市场被曝出严重漏洞,TreasureDAO 是一个基于 Arbitrum(L2)上的 NFT 项目。目前项目团队正在修复漏洞并承诺会对受影响的用户提供解决方案。慢雾安全团队第一时间介入分析,并将结果分享如下:


相关信息


合约地址

TreasureMarketplaceBuyer:

0x812cda2181ed7c45a35a691e0c85e231d218e273


TreasureMarketplace:

0x2e3b85f85628301a0bce300dee3a6b04195a15ee


漏洞细节分析


1. 用户通过 TreasureMarketplaceBuyer 合约中的 buyItem 函数去购买 NFT,该函数会先计算总共需要购买的价格并把支付所需的代币打入合约中,接着调用 TreasureMarketplace 合约中的 buyItem 从市场购买 NFT 到  TreasureMarketplaceBuyer  合约,接着在从 TreasureMarketplaceBuyer 合约中把 NFT 转给用户。


“零元购” —— TreasureDAO NFT 交易市场漏洞分析

2. 在 TreasureMarketplace 合约中:


“零元购” —— TreasureDAO NFT 交易市场漏洞分析


可以发现若传入的 _quantity 参数为 0,则可以直接通过 require(listedItem.quantity >= _quantity, “not enough quantity”); 检查并进入下面的转移 NFT 流程,而其中没有再次对 ERC-721 标准的 NFT 转移进行数量判断,使得虽然传入的 _quantity 参数虽然为 0,但仍然可以转移 ERC-721 标准的 NFT。而计算购买 NFT 的价格的计算公式为 totalPrice = _pricePerItem * _quantity,因此购买 NFT 的价格被计算为 0,导致了在市场上的所有 ERC-721 标准的 NFT 均可被免费购买。


攻击交易分析


此处仅展示一个攻击交易的细节,其余攻击交易的手法都一致,不再赘述。


攻击交易:

https://arbiscan.io/tx/0x82a5ff772c186fb3f62bf9a8461aeadd8ea0904025c3330a4d247822ff34bc02


攻击者:

0x4642d9d9a434134cb005222ea1422e1820508d7b


攻击细节:


“零元购” —— TreasureDAO NFT 交易市场漏洞分析


可以从下图中看到,攻击者调用了 TreasureMarketplaceBuyer 合约中的 buyItem 函数,并使传入的 _quantity 参数为 0。


“零元购” —— TreasureDAO NFT 交易市场漏洞分析


可以看到代币转移均为 0,攻击者并没有付出任何成本就成功购买了 tokenID 为 3557 的 NFT,整个攻击流程与上面的漏洞细节分析中所讲的一致。


总结


本次漏洞的核心在于进行 ERC-721 标准的 NFT 转移前,缺少了对于传入的 _quantity 参数不为 0 的判断,导致了 ERC-721 标准的 NFT 可以直接被转移且计算价格时购买 NFT 所需费用被计算成 0。针对此类漏洞,慢雾安全团队建议在进行 ERC-721 标准的 NFT 转移前,需对传入的数量做好判断,避免再次出现此类问题。


往期回顾

链上追踪:洗币手法科普之 Peel Chain

慢雾:美国执法部门破获 2016 年 Bitfinex 被黑案件细节分析

重建世界:The Sandbox 任意燃烧漏洞回顾

8000 万美元不翼而飞 —— QBridge 被黑简析

慢雾科技四周年,做区块链黑暗森林的那束光

“零元购” —— TreasureDAO NFT 交易市场漏洞分析

慢雾导航


慢雾科技官网

https://www.slowmist.com/


慢雾区官网

https://slowmist.io/


慢雾 GitHub

https://github.com/slowmist


Telegram

https://t.me/slowmistteam


Twitter

https://twitter.com/@slowmist_team


Medium

https://medium.com/@slowmist


知识星球

https://t.zsxq.com/Q3zNvvF


原文始发于微信公众号(慢雾科技):“零元购” —— TreasureDAO NFT 交易市场漏洞分析

版权声明:admin 发表于 2022年3月3日 下午3:13。
转载请注明:“零元购” —— TreasureDAO NFT 交易市场漏洞分析 | CTF导航

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...