Back to Blog

Vee Finance 安全事件的真正根源

Code Auditing
September 22, 2021
3 min read

VEE finance 發布了關於近期安全事件的報告。在該報告中,他們指出根本原因是「操縱 VEE Finance 預言機價格,且獲取預言機價格的過程未處理小數點,導致交易前的預期滑點檢查失效。」

「此次事故的主要原因是,在創建槓桿交易訂單的過程中,預言機僅使用 Pangolin 流動性池的價格作為價格來源,且池內價格波動超過 3%。預言機刷新了價格,導致攻擊者操縱了 Pangolin 池的價格。操縱 VEE Finance 預言機價格且獲取預言機價格的過程未處理小數點,導致交易前的預期滑點檢查失效。」——引用自 VEE finance 發布的報告。

然而,經過我們仔細調查,我們發現事實並非如此。真正的原因是攻擊者創建了一個虛假的 ctokenB 並將其傳遞給合約。由於 ctokenB 由攻擊者控制,它可以返回用於計算代幣價格的任意底层代幣。這才是攻擊的真正根本原因。

整個過程

合約中存在一個名為 createOrderERC20ToERC20 的外部函數,任何用戶都可以調用它來創建代幣兌換,該函數使用通過將抵押品放入合約而獲得的 ctokenctoken 具有代表真實代幣的底层代幣(underlying token)。

在正常情況下,當調用 createOrderERC20ToERC20 使用槓桿交易代幣對時,DApp 需要確保該交易不會產生任何損失(否則 DApp 將會虧損)。這是通過調用 getAmountOutMin 函數來強制執行的。

假設我們將 0.95 ETH 放入 DApp 並獲得價值 0.5 ETH 的 ctoken(超額抵押)。那麼我們可以利用 3 倍槓桿要求 DApp 代表用戶以 1.5 ETH 的金額交易另一種代幣(假設為 tokenX)。在這種情況下,為了防止損失,DApp 需要確保交易後的 tokenX 價值不能低於 0.95 * 1.5 ETH(否則 DApp 將面臨虧損風險)。DApp 利用外部價格預言機來計算 ETH 和 tokenX 的價值。

然而,createOrderERC20ToERC20 函數並沒有驗證傳入的 ctokenB。因此,攻擊者可以實現自己的合約作為 ctokenB 並將其提供給 createOrderERC20ToERC20 函數。結果是,這個虛假的 ctokenBcreateOrderERC20ToERC20getAmountOutMin 中被調用時,可以將底层代幣返回為 LINK (0x5947bb275c521040051d82396192181b413227a3),但在 IPriceOracle(oracle).getUnderlyingPrice(createParams.ctokenB) 被調用時,卻將底层代幣返回為 BTC。因此,它可以繞過 isRightPrice 的檢查——因為用於計算價格的代幣是 BTC(而不是 LINK)。這可以由 priceB 的返回值 0x15e1549d1216fe9fc032e7c00000 (443783124870000000000000000000000) 來證實。這正是 BTC 的價格。

結論

總之,攻擊者利用了 ctokenB 缺乏檢查的漏洞。由於 ctokenB 並非受信任的合約,因此 ctokenB 返回的底层代幣不可信。然而,在此次攻擊中,價格預言機本身並沒有被攻破。

總結與建議

確保 DeFi 項目的安全並非易事。除了代碼審計外,我們認為社區應該採取主動的方法來監控項目狀態,並在攻擊發生前進行攔截

關於 BlockSec

BlockSec 是一家開創性的區塊鏈安全公司,由一群全球知名的安全專家於 2021 年創立。公司致力於增強新興 Web3 世界的安全性和可用性,以促進其大規模採用。為此,BlockSec 提供智能合約與 EVM 鏈的安全審計服務、用於安全開發與主動威脅阻斷的 Phalcon 平台、用於資金追蹤與調查的 MetaSleuth 平台,以及協助 Web3 建構者在加密世界中高效探索的 MetaSuites 瀏覽器插件。

迄今為止,公司已服務超過 300 家知名客戶,如 MetaMask、Uniswap Foundation、Compound、Forta 和 PancakeSwap,並已獲得包括 Matrix Partners、Vitalbridge Capital 和 Fenbushi Capital 在內的頂尖投資機構兩輪數千萬美元的融資。

官方網站:https://blocksec.com/

官方 Twitter 帳號:https://twitter.com/BlockSecTeam

Sign up for the latest updates
~$598萬損失:Aztec、Raydium等|BlockSec週報
Security Insights

~$598萬損失:Aztec、Raydium等|BlockSec週報

本週區塊鏈安全報告涵蓋2026年6月8日至15日,分析以太坊和Solana上4起重大事件,總損失約598萬美元。重點事件包括:Aztec Connect因缺少輸入驗證導致rollup證明路徑與L1結算狀態不一致;Raydium因舊版AMM v3程式缺少驗證,攻擊者操縱LP代幣贖回計算並清空四個池。兩個漏洞均存在多年後才被利用。報告涵蓋輸入驗證缺失、整數溢出及治理攻擊等類型。

Zcash Orchard 健全性漏洞分析 | BlockSec 週報
Security Insights

Zcash Orchard 健全性漏洞分析 | BlockSec 週報

2026年6月1日當週,Zcash Orchard隱私池電路被公開披露存在嚴重健全性漏洞。該漏洞由halo2 ECC標量乘法組件缺少等式約束引起,可能導致透過雙重支付在Orchard池中無法被偵測地偽造ZEC。此漏洞自2022年5月Orchard啟用以來已存在逾四年,由研究員Taylor Hornby使用Anthropic Opus 4.8模型進行AI輔助安全審計時發現,並透過緊急網路升級(NU6.2)修補。本報告涵蓋技術根本原因、AI輔助發現過程、緊急應對時間軸及對ZKP生態系統的影響。

通訊 - 2026年5月
Security Insights

通訊 - 2026年5月

2026年5月,DeFi生態發生三起重大安全事件。Echo Protocol因管理員密鑰外洩遭惡意增發eBTC,損失約7,670萬美元;StablR因多簽治理漏洞被非法發行穩定幣,損失約1,280萬美元;Verus-Ethereum Bridge因類型驗證失敗導致攻擊,損失約1,170萬美元。

Best Security Auditor for Web3

Validate design, code, and business logic before launch. Aligned with the highest industry security standards.

BlockSec Audit