“零元购” 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 转给用户。

DASH突破72美元关口 日内涨幅为1.32%:火币全球站数据显示,DASH短线上涨,突破72美元关口,现报72.03美元,日内涨幅达到1.32%,行情波动较大,请做好风险控制。[2020/10/14]

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 转移前,需对传入的数量做好判断,避免再次出现此类问题。

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

链杂谈

MATIC为什么游戏玩家在表达“讨厌” NFT之前应该三思而后行?

每个举动都得到一个相等和相反的反应。 去年,NFT 蓬勃发展。 他们成为了加密的典型代表——可数字验证的私人所有权。 创造了财富。 同时也催生了炒作。 反过来,我们也看到了反抗 NFT 的本能反应,尤其是来自游戏生态系统的。 我认为这种怨恨是错误的。 NFT 不是为了剥削游戏玩家。 NFT为游戏玩家提供选择的自由。

币安app官网下载Filecoin 加快升级步伐

Filecoin网络在3月1日刚刚升级到 Network Version #15,目前的重头戏是FVM(Filecoiin虚拟机),这个部分要分好几步进行,第一步,也就是Network Version #16计划于2022年5月3日进行。Filecoin网络的改进处于快速发胀之中,升级的步伐可能加快。

XRP金色前哨|合成资产协议Synthetix升级清算机制

金色财经报道,北京时间3月11日,合成资产协议Synthetix发布了最新博文,文章中提到,将大约两周内发布并实施一个新清算机制,彻底改革之前的系统。这种新机制将加强协议并确保连续清算不会破坏Synthetix协议的稳定性。

[0:15ms0-0:484ms