-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
了解智能合約中的重入攻擊(DAO 黑客解釋)
A reentrancy attack exploits Ethereum’s execution model by recursively calling a vulnerable function before state updates, as seen in The DAO hack—where $50M was drained due to updating balances after external calls.
2026/01/16 01:40
什麼是重入攻擊?
1. 當外部合約在初始執行完成之前回調當前合約時,就會發生重入攻擊。
2. 此漏洞是由於不正確的狀態管理而產生的,具體來說,當狀態變量在外部調用之後而不是之前更新時。
3. 攻擊者部署包含回退函數的惡意合約,該函數會遞歸調用目標合約中的易受攻擊函數。
4. 每個遞歸調用都會重新進入相同的邏輯路徑,反复耗盡資金,而不會更新余額,直到整個調用堆棧展開。
5. 此類攻擊利用以太坊的同步、單線程執行模型,其中外部調用在調用上下文中保留控制流。
DAO 事件:歷史崩潰
1. DAO 是 2016 年在以太坊上推出的去中心化自治組織,旨在作為受智能合約規則管理的風險投資基金。
2.其代碼允許代幣持有者從 DAO 中分離出來,並通過調用splitDAO函數來回收以太幣。
3. 該函數在更新內部餘額之前將以太幣轉移到請求者的地址,創建一個經典的可重入窗口。
4. 攻擊者部署了具有後備功能的合約,在收到資金後再次觸發splitDAO 。
5. 在多次嵌套調用中,超過 360 萬 ETH(當時價值超過 5000 萬美元)在交易恢復或停止之前被抽走。
以太坊的執行模型如何實現可重入
1. Solidity 中的每個外部調用都在相同的事務上下文中執行,保留內存、存儲和調用堆棧的可見性。
2. 除非通過“檢查-效果-交互”等模式顯式實現,否則不存在自動重入防護。
3. Gas limit 並不能阻止遞歸;它們僅限制總計算量,並且回退函數需要最少的 Gas 來執行。
4. EVM 不強制調用者和被調用者之間的隔離——被調用者所做的狀態更改在其持續執行期間對調用者是可見的。
5. 開發人員經常低估合約交互的相互依賴程度,尤其是在涉及第三方代幣或預言機時。
需要重入的常見代碼模式
1. 在發送以太幣或調用外部合約(而不是之前)之後更新余額或標誌。
2. 使用call.value()()而不驗證返回值或限制遞歸深度。
3.依靠this.balance進行記賬,而不是跟踪存儲變量中的餘額。
4. 實現沒有鎖、互斥體或重入修飾符(例如 OpenZeppelin 的ReentrancyGuard)的撤回模式。
5. 未能審核繼承邏輯——尤其是在使用代理模式或可升級合約(其中 delegatecall 保留上下文)時。
常見問題解答
問:ERC-20 轉賬會發生重入嗎?答:標準 ERC-20 傳輸函數不會觸發外部調用,因此無法實現原生重入。然而,諸如transferFrom之類的擴展與鉤子(例如,在ERC-777中)相結合引入了可能發生重入的回調表面。
問:DAO 黑客攻擊是否會因為硬分叉而可逆?答:是的。以太坊社區執行了硬分叉,通過重寫鏈歷史來恢復被盜資金,導致以太坊和以太坊經典分裂。
問:現代 Solidity 版本默認情況下會阻止重入嗎?答:不會。 Solidity v0.8.x 包括更安全的算術和恢復行為,但不會自動注入重入保護。開發人員仍然必須手動應用防禦模式。
問:使用require(msg.sender.call{value: amount}(''))比address.send()更安全嗎?答:兩者本質上都不是安全的。如果在狀態更新之前使用,兩者都允許重入。關鍵因素是交互順序,而不是特定的調用機制。
免責聲明:info@kdj.com
所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!
如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。
- Coinbase 與 Crypto ISAC 結成聯盟,為數字資產世界的安全情報製定新標準
- 2026-01-31 04:35:01
- 美國造幣廠以 2026 年薩卡加維亞硬幣紀念革命戰爭英雄波莉·庫珀
- 2026-01-31 03:55:01
- 避險拋售狂潮中,比特幣觸及 8.3 萬美元,ETF 出現大規模資金外流
- 2026-01-31 04:35:01
- 新版 2026 年一元硬幣彰顯奧奈達女英雄波莉·庫珀和美國的第一批盟友
- 2026-01-31 04:15:01
- 奧奈達女性波莉·庫珀因革命戰爭英雄主義榮獲 2026 年 1 美元硬幣
- 2026-01-31 04:25:01
- 奧奈達女英雄波莉·庫珀在新版 1 美元硬幣上永垂不朽:對革命慷慨的遲來的致敬
- 2026-01-31 04:25:01
相關知識
如何使用LayerZero合約執行跨鏈消息?
2026-01-18 13:19:39
了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...
如何實施EIP-712進行安全簽名驗證?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定義了以太坊應用程序中類型化結構化數據哈希和簽名的標準。 2. 它使錢包能夠在簽名請求期間顯示人類可讀的域和消息字段,而不是原始的十六進製字符串。 3. 該規範通過域分隔符哈希引入域分離,防止跨不同 dApp 或鏈的簽名重放。 4. 每個簽名的有效...
如何通過新合約交互獲得空投資格?
2026-01-24 21:00:23
了解合約交互要求1. 大多數空投活動都要求與部署在受支持的區塊鏈(例如以太坊、Arbitrum 或 Base)上的智能合約進行直接交互。 2. 交互通常涉及使用連接到 dApp 接口的錢包執行諸如approve() 、 stake()或mint()之類的函數。 3. 某些協議需要多種交易類型,例如將...
如何監控智能合約的安全警報?
2026-01-21 07:59:57
鏈上監控工具1. Etherscan和Blockscout等區塊鏈瀏覽器允許實時檢查合約字節碼、交易日誌和內部調用。 2. 在信任任何鏈上數據之前必須確認合約驗證狀態——未經驗證的合約存在高風險。 3. 事件日誌解析可以檢測異常狀態變化,例如意外的代幣轉移或所有權修改。 4. 可以針對特定事件簽名設...
如何建立自動支付合同並為其提供資金?
2026-01-26 08:59:35
了解智能合約部署1. 開發者必鬚根據gas效率和安全性要求選擇兼容的區塊鏈平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是編寫支付自動化邏輯的主要語言,特別是對於定期或有條件的轉賬。 3. 在主網部署之前,使用 Hardhat 或 Foundry 等本地開發環境來...
如何使用 OpenZeppelin 合約構建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...
如何使用LayerZero合約執行跨鏈消息?
2026-01-18 13:19:39
了解 LayerZero 架構1. LayerZero 作為一種輕量級、無需許可的互操作性協議運行,無需依賴可信中介或包裝資產即可實現區塊鏈之間的通信。 2. 它利用部署在每條鏈上的超輕節點(ULN)來驗證消息的完整性和一致性,而無需存儲完整的區塊鏈狀態。 3. 核心組件包括處理消息路由的 Endp...
如何實施EIP-712進行安全簽名驗證?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定義了以太坊應用程序中類型化結構化數據哈希和簽名的標準。 2. 它使錢包能夠在簽名請求期間顯示人類可讀的域和消息字段,而不是原始的十六進製字符串。 3. 該規範通過域分隔符哈希引入域分離,防止跨不同 dApp 或鏈的簽名重放。 4. 每個簽名的有效...
如何通過新合約交互獲得空投資格?
2026-01-24 21:00:23
了解合約交互要求1. 大多數空投活動都要求與部署在受支持的區塊鏈(例如以太坊、Arbitrum 或 Base)上的智能合約進行直接交互。 2. 交互通常涉及使用連接到 dApp 接口的錢包執行諸如approve() 、 stake()或mint()之類的函數。 3. 某些協議需要多種交易類型,例如將...
如何監控智能合約的安全警報?
2026-01-21 07:59:57
鏈上監控工具1. Etherscan和Blockscout等區塊鏈瀏覽器允許實時檢查合約字節碼、交易日誌和內部調用。 2. 在信任任何鏈上數據之前必須確認合約驗證狀態——未經驗證的合約存在高風險。 3. 事件日誌解析可以檢測異常狀態變化,例如意外的代幣轉移或所有權修改。 4. 可以針對特定事件簽名設...
如何建立自動支付合同並為其提供資金?
2026-01-26 08:59:35
了解智能合約部署1. 開發者必鬚根據gas效率和安全性要求選擇兼容的區塊鏈平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是編寫支付自動化邏輯的主要語言,特別是對於定期或有條件的轉賬。 3. 在主網部署之前,使用 Hardhat 或 Foundry 等本地開發環境來...
如何使用 OpenZeppelin 合約構建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合約基礎知識1. OpenZeppelin Contracts 是一個可重用、經過社區審核的智能合約組件庫,專為以太坊和 EVM 兼容的區塊鏈而構建。 2. 庫中的每個合約都遵循嚴格的安全實踐,包括遵守“檢查-效果-交互”模式以及廣泛使用訪問控制修飾符。 3. 該庫提...
看所有文章














