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

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

相关信息

合约地址

TreasureMarketplaceBuyer:

0x812cda2181ed7c45a35a691e0c85e231d218e273

TreasureMarketplace:

0x2e3b85f85628301a0bce300dee3a6b04195a15ee

漏洞细节分析

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

2. 在 TreasureMarketplace?合约中:

可以发现若传入的 _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

攻击细节:

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

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

总结

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

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

链链资讯

OKB怎么设计好链游的经济模型?先看看传统游戏是如何抑制通货膨胀问题的

译者语:一个游戏的经济模型,该如何搭建才能保证最大的生命力?这一问题,无论是传统游戏大厂还是GameFi开发者,都需要认真思考。在抑制游戏内通货膨胀的问题上,传统游戏和GameFi有着共同的追求,只是动机不同。 我们认为,在GameFi概念爆发的现在,亟需树立更为立体和底层的认知,才能在接下来的布局中,占据先机。

AVAX自2021年7月以来 交易所比特币总流入量为净负数

Glassnode的数据显示,自去年7月以来,除Binance、FTX、Bittrex和Bitfinex外,大多数交易所的资金流出超过资金流入,这表明卖家可能已经耗尽。 自去年 7 月以来,所有交易所的比特币流入量一直为净负,但四家主要交易所的比特币净流入却与这一趋势相反,几乎都为正。

比特币交易为什么说L2扩展可能比Eth2.0合并更重要?

L2 可能是未来 12-24 个月以太坊扩展的最重要部分。 甚至超过Eth2.0合并。 因此,我想对 L2 的发展方式以及它们的未来发展方向进行一些研究。 在过去的 12 个月中,L2 的增长非常惊人。总锁定价值(TVL)从 2021 年 1 月的 5000 万美元增长到今天的约55亿美元,增长了约 100 倍。

[0:0ms0-4:39ms