Cointime

扫码下载App
iOS & Android

详解Socket攻击事件始末

项目方

2024 年 1 月 16 日,Socket Tech遭到攻击,损失约 330 万美元。 攻击者利用了Socket某合约中数据验证环节的漏洞,通过恶意数据输入盗取了授权合约的用户资金。 这次攻击共给 230 个地址带来损失,最大的单地址损失约为 65.6 万美元。

背景介绍

Socket 是一种服务于跨链安全、高效数据和资产传输的互操作性协议。 Socket Gateway合约是与 Socket 流动性层所有交互的接入点,所有资产桥接器和 DEX 在此汇聚成一个唯一的元桥接器,并根据用户偏好(如成本、延迟或安全性)选择最佳交易路由。

黑客攻击发生的前三天,Socket合约管理员执行了addRoute命令,在系统中加入了一条新路由。 添加路由的目的是扩展Socket网关的功能,但却无意中引入了一个关键漏洞。

下图为通过合约管理员添加路由的记录

事件梗概

  1. 1,北京时间1月16日15:03,攻击者钱包转入攻击所用资金,我们的时间分析表明这笔资金来自0xe620,与从Tornado Cash提取的10 BNB有关。

  1. 2,这些资金被用于创建和执行两个合约,来利用Socket的漏洞。 第一个合约针对的是授权了 SocketGateway 的地址中的 USDC(截图如下);127 名受害者被骗走约 250 万美元。

  1. 3,接下来,第二个合约则将目标对准了受害者地址内的WETH, USDT, WBTC, DAI 与MATIC。于是,另外104名受害者损失了如下资产:
  • 42.47526105 WETH
  • 347,005.65 USDT
  • 2.88962154 WBTC
  • 13,821.01 DAI
  • 165,356.99 MATIC
  1. 4,攻击者将USDC与USDT转换成了ETH。

漏洞来源

被攻击者利用的漏洞存在于新添加的路由地址 routeAddress内的performAction函数中。

该地址内的performAction函数原本的功能是协助Wrapping与Unwrapping的功能。 然而,该函数中出现了一个关键漏洞:用户在无需验证的情况下,直接在.call() 中通过swapExtraData调用外部数据,这意味着攻击者可以执行任意恶意函数。

在这次事件中,攻击者制作了一个恶意的 swapExtraData 输入,触发transferFrom函数。 该恶意调用利用了用户对 SocketGateway 合约的授权,从他们那里盗走了资金。

虽然合约会通过检查余额检查确保 fromToken.call() 调用后用户余额会出现正确的变化,但该函数没有考虑攻击者将金额设置为0的情况。

还原攻击流程

  1. 1,使用攻击合约,攻击者在Socket Gateway合约上调用了0x00000196()。

  1. 2,fallback() 使用六进制签名 196 调用了有漏洞的路由地址合约(routerAddress)。

  1. 3,在下面的截图中,我们可以看到攻击者使用的虚假输入,Swapping数量全部为0。

  1. 4,接下来将调用WrappedTokenSwapperImpl.performAction() 进行Swap。

  1. 5,在没有进行任何验证的情况下,虚假的SwapExtraData被fromToken (WETH)接受并执行。

  1. 6,攻击者重复执行以上流程,直到受害者资产耗尽。 恶意交易出现后,Socket 迅速调用了 disableRoute,屏蔽了之前有漏洞的路由,阻止了更大范围的攻击。
  2. 7,1月23日,Socket宣布已经追回1032枚ETH,并在25日宣布将全额补偿所有损失。本次事件得到解决。

事件总结

在有着无限额用户授权的路由合约中,恶意 calldata 攻击并不罕见。 以前类似的攻击包括 Dexible 和 Hector Bridge。 2023 年 2 月 17 日,去中心化交易所 Dexible 被攻击,损失超过 150 万美元。 漏洞利用者向 Dexible 的 fill() 函数输入恶意 calldata,以窃取用户资产。 2023 年 6 月 2 日,Hector 网络的协议被攻击。攻击者部署了一个虚假的 USDC合约,并通过恶意 calldata,将 65.2万枚真实的USDC从受害者的合约中转移出去。

区块链聚合平台通常通过封装一系列桥和路由合约来提高流动性,减少损耗。然而,这种复杂的封装会给安全性带来更多难题。我们欣慰地看到Socket此次事件可以得到解决,CertiK将继续致力于为平台提供全方位审计与检测,降低各类聚合风险,提高社区信任和整个行业的安全水平

评论

所有评论

推荐阅读

  • 美国已拒绝伊朗就结束战争提出的书面方案

    5月15日电,据伊朗《德黑兰时报》15日报道,美国已拒绝伊朗就结束战争提出的“14点”书面方案。报道称,美国政府已就上述书面方案作出回应,美国拒绝了德黑兰的方案,并“重申其强硬立场”,尤其是在核问题上。伊朗提出的方案基于两阶段谈判程序:第一阶段旨在结束所有战线的战争;如果伊朗的条件得到满足,则将启动关于核问题的第二阶段谈判。 (新华社)

  • BTC突破81000美元

    行情显示,BTC突破81000美元,现报81003.37美元,24小时涨幅达到1.54%,行情波动较大,请做好风险控制。

  • 日本央行警告投资基金活动或引发金融体系风险

    5月15日,日本央行理事神山一成(Kazushige Kamiyama)在一份演讲稿中指出,投资基金在提供风险资本方面发挥着关键作用,但也可能给一国的金融体系带来潜在风险。神山一成表示:“全球对冲基金资金流向的突然转变,可能会加剧债券和股票市场的价格波动。”

  • 韩国首尔���指跌幅扩大至7%,现报7421.91点

    5月15日消息,韩国首尔综指跌幅扩大至7%,现报7421.91点。

  • 美国国债收益率创下数月新高

    5月15日,霍尔木兹海峡实际上仍处于关闭状态,同时对通胀的担忧依然存在,亚洲交易时段美国国债收益率上升。Tradeweb的数据显示,美国两年期国债收益率触及4.064%,为2025年2月以来的最高水平。美国10年期国债收益率升至4.530%的一年高点,美国30年期国债收益率升至5.071%,为2025年7月以来的最高水平。数据显示,在触及这些水平后,收益率有所回落,但仍较前交易日高出6-8个基点。(东新社)

  • 特朗普:热情期待在华盛顿接待习近平主席

    美国总统特朗普15日表示,非常感谢习近平主席邀请我到中南海做客。此次访华是一次非常成功的访问,举世瞩目,令人难忘。我愿同习近平主席继续保持诚恳深入沟通,热情期待在华盛顿接待习近平主席。(新华社)

  • 日经225指数向下触及61000点,日内跌2.65%

    日经225指数向下触及61000点,日内跌2.65%。

  • 韩国首尔综指暴跌5%

    5月15日,韩国首尔综指重挫5%,受三星和SK海力士拖累,其中三星电子跌幅扩大至7%。

  • 美股股指期货持续下挫,纳指期货跌幅扩大至1%

    5月15日消息,美股股指期货持续下挫,纳指期货跌幅扩大至1%,标普500指数期货跌0.60%。