-
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%
如何防止固體重新進入?
Reentrancy in Solidity occurs when an external call allows a malicious contract to recursively execute the same function, potentially draining funds or corrupting state.
2025/07/20 08:49
了解堅固的重新註入
重新輸入是固體智能合約中的關鍵安全漏洞,當功能在完成內部狀態變更之前對不受信任的合同進行外部呼叫時,就會發生。這使外部合同可以遞歸地回到原始功能,可能耗盡資金或破壞合同的邏輯。
2016年臭名昭著的DAO黑客是如何利用重新進入的一個典型例子。攻擊者使用惡意的後備功能在合同更新其餘額之前反复觸發撤離,從而導致數百萬的以太幣損失。
為了防止此類漏洞,開發人員必須實施最佳實踐和設計模式,以確保外部呼叫並確保在任何外部互動之前發生狀態變化。
使用檢查效應互動模式
防止重新進入的最有效方法之一是遵循檢查效應互動模式。此模式可確保在執行任何外部呼叫之前進行所有內部狀態更改。
- 檢查:驗證輸入和條件。
- 效果:更新合同的狀態變量。
- 互動:致電外部合同或發送以太。
通過遵守此訂單,您可以確保即使發生重新輸入嘗試,內部狀態也已被更新,以防止雙人支出或未經授權的餘額訪問。
例如,考慮一個簡單的提款功能:
function withdraw(uint amount) public {require(balances[msg.sender] >= amount); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success);
}
在這種情況下,餘額將在外部呼叫之前進行更新,從而使其免受重新輸入。
實現Mutex鎖
防止重新進入的另一種有效方法是使用MUTEX鎖定,這是一種防止執行過程中重新進入的狀態變量。
一個簡單的示例涉及使用布爾標誌來阻止重新進入:
bool private locked;函數提取(UINT金額)public {require(!locked); locked = true; require(balances[msg.sender] >= amount); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success); locked = false;}
這樣可以確保該函數在仍在執行時無法重新輸入,從而有效地阻止了遞歸調用。但是,開發人員在使用靜音時必須謹慎,以免產生僵局或意外行為。
使用openzeppelin的重新進入守衛
開發人員無需手動實施Mutex邏輯,而是使用OpenZeppelin提供的重新進入守衛合同,該合同提供了安全且經過測試的解決方案。
使用重新輸入守衛:
- 導入合同:
import '@openzeppelin/contracts/security/ReentrancyGuard.sol'; - 您的合同中繼承它:
contract MyContract is ReentrancyGuard - 將
nonReentrant修飾符應用於容易重新進入的功能。
pragma solidity ^0.8.0;導入'@openzeppelin/contracts/security/recentrancyguard.sol';合同securewithDrawal是重新進入guart {
mapping(address => uint) public balances; function deposit() external payable { balances[msg.sender] += msg.value; } function withdraw(uint amount) external nonReentrant { require(balances[msg.sender] >= amount, 'Insufficient balance'); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success, 'Transfer failed'); }}
這種方法抽象了靜音處理的複雜性,並降低了引入錯誤的風險,使其成為許多開發人員的首選方法。
避免原始呼叫並安全使用轉移
在堅固的情況下,使用address.call{value: ...}('')比transfer()或send()更靈活,但它也消除了氣體限制,使其容易受到重新進入。
-
transfer()和send()僅向前轉發2300天氣,這不足以進行任何有意義的執行,從而防止重新進入。 - 但是,
call()轉發所有可用的氣體,使攻擊者可以在後備或接收功能期間執行複雜的惡意邏輯。
為此緩解:
- 對於簡單的以太轉移,更喜歡
transfer()或send()。 - 如果需要使用
call(),請確保狀態變化發生在呼叫之前發生,並將重新進入警衛隊進行。
常見問題解答:常見問題
問:什麼是固體攻擊是什麼?答:當外部合同完成執行之前,外部合同回到呼叫功能時,會發生重新進入攻擊,通常會導致未經授權的基金提款或州腐敗。
問:我可以在不使用Openzeppelin的重新進入守衛的情況下防止重新進入嗎?答:是的,通過手動實現檢查效應互動模式或使用靜音鎖定在執行功能期間的重新輸入。
問:在現代固體版本中使用address.transfer()安全嗎?答:雖然transfer()限制氣體並防止重新進入,但如果收件人合同用盡了氣體,則可能意外失敗。對於簡單的傳輸,它仍然比call()更安全。
問:所有外部呼叫的堅固性是否容易被重新進入?答:不是全部,但是對用戶控制合同的任何外部呼叫都可以是潛在的向量。當狀態變化遵循外部呼叫而不是呼叫本身時,就會出現漏洞。
免責聲明:info@kdj.com
所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!
如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。
- 比特幣、eCash 分叉和空投動態:深入探討加密貨幣的最新爭議
- 2026-05-03 12:55:01
- 2026 年邁阿密共識:Web3、區塊鏈、加密貨幣、NFT、Metaverse,會議,5 月 5 日 — 華爾街與數位前沿相遇的地方
- 2026-05-02 12:45:01
- 聯準會維持利率穩定,地緣政治緊張局勢引發比特幣價格下跌
- 2026-05-01 06:45:01
- 比特幣礦工為電網供電:收購俄亥俄州天然氣廠開啟數位黃金新時代
- 2026-05-01 00:45:01
- MegaETH的MEGA代幣登陸紐約:為即時區塊鏈設定新的效能基準
- 2026-05-01 00:55:01
- Solana 的滑坡:價格預測顯示阻力損失和潛在的進一步下跌
- 2026-05-01 06:45:01
相關知識
什麼是資金費率翻轉?為什麼它經常預示著市場情緒的變化
2026-06-14 03:57:05
市場波動模式1. Bitcoin 在重大宏觀經濟公告期間,24 小時內價格波動往往超過 10%。 2. 在合併事件期間,以太坊的波動性指數飆升至 95 以上,反映出 Layer 1 和 Layer 2 生態系的深度流動性碎片化。 3. 穩定幣脫鉤——例如 USDC 在 2023 年 3 月暫時偏離至...
如何辨識加密貨幣期貨市場中的市場操縱訊號
2026-06-12 17:26:02
Bitcoin 減半機制1. Bitcoin 的協議強制執行固定的發行時間表,其中大約每 210,000 個區塊,區塊獎勵就會減少一半。 2. 該事件大約每四年發生一次,直接減少每個區塊新進入流通的 BTC 數量。 3.截至2020年減半,礦工每區塊獲得6.25 BTC;下一次減少將使其達到 3.1...
什麼是槓桿陷阱?為什麼零售貿易商經常被抓
2026-06-12 23:53:36
市場波動模式1. Bitcoin 在 ETF 批准公告或重大交易所中斷等高流動性事件期間,24 小時視窗內價格波動通常超過 5%。 2. 以太坊的波動性高峰與第 2 層採用指標密切相關,特別是當新的 Rollup 在主網上線並經歷快速用戶成長時。 3. 穩定幣脫鉤事件(例如 2023 年 3 月的 ...
什麼是突破交易?期貨交易者如何捕捉大幅價格變動
2026-06-13 05:19:40
了解加密貨幣期貨的突破機制1. 當 Bitcoin 或山寨幣價格果斷突破既定阻力位且交易量持續激增時,就會發生突破,通常會引發槓桿多頭頭寸的級聯清算。 2. 在永續合約市場中,突破經常與融資利率飆升和未平倉合約擴張同時發生,這表明機構參與而不是散戶噪音。 3. 與現貨市場不同,加密貨幣期貨的突破會被...
高槓桿期貨部位的最佳停損策略是什麼?
2026-06-14 14:19:32
高槓桿期貨交易中的停損機制1. 停損設定必須符合價格擴散的統計特性,而不是任意的百分比門檻。在能源期貨價差等均值回歸市場中,最佳停損水準源自奧恩斯坦-烏倫貝克動力學下的首次退出時間分佈。 2. 固定的 1% 或 2% 停損忽略了波動性聚集和狀態轉變。對暖氣油/天然氣-油半小時資料的實證回溯測試表明,...
如何在重大經濟公告期間交易加密貨幣期貨
2026-06-12 22:50:44
市場波動模式1. Bitcoin 在減半公告或主要交易所上市等高流動性事件期間,單一 24 小時視窗內的價格波動通常超過 5%。 2. 過去 36 個月,山寨幣與 BTC 的相關性平均高於 0.78,顯示對 Bitcoin 方向性走勢的強烈依賴。 3. 期貨未平倉合約的飆漲常常先於急劇逆轉-尤其是當...
什麼是資金費率翻轉?為什麼它經常預示著市場情緒的變化
2026-06-14 03:57:05
市場波動模式1. Bitcoin 在重大宏觀經濟公告期間,24 小時內價格波動往往超過 10%。 2. 在合併事件期間,以太坊的波動性指數飆升至 95 以上,反映出 Layer 1 和 Layer 2 生態系的深度流動性碎片化。 3. 穩定幣脫鉤——例如 USDC 在 2023 年 3 月暫時偏離至...
如何辨識加密貨幣期貨市場中的市場操縱訊號
2026-06-12 17:26:02
Bitcoin 減半機制1. Bitcoin 的協議強制執行固定的發行時間表,其中大約每 210,000 個區塊,區塊獎勵就會減少一半。 2. 該事件大約每四年發生一次,直接減少每個區塊新進入流通的 BTC 數量。 3.截至2020年減半,礦工每區塊獲得6.25 BTC;下一次減少將使其達到 3.1...
什麼是槓桿陷阱?為什麼零售貿易商經常被抓
2026-06-12 23:53:36
市場波動模式1. Bitcoin 在 ETF 批准公告或重大交易所中斷等高流動性事件期間,24 小時視窗內價格波動通常超過 5%。 2. 以太坊的波動性高峰與第 2 層採用指標密切相關,特別是當新的 Rollup 在主網上線並經歷快速用戶成長時。 3. 穩定幣脫鉤事件(例如 2023 年 3 月的 ...
什麼是突破交易?期貨交易者如何捕捉大幅價格變動
2026-06-13 05:19:40
了解加密貨幣期貨的突破機制1. 當 Bitcoin 或山寨幣價格果斷突破既定阻力位且交易量持續激增時,就會發生突破,通常會引發槓桿多頭頭寸的級聯清算。 2. 在永續合約市場中,突破經常與融資利率飆升和未平倉合約擴張同時發生,這表明機構參與而不是散戶噪音。 3. 與現貨市場不同,加密貨幣期貨的突破會被...
高槓桿期貨部位的最佳停損策略是什麼?
2026-06-14 14:19:32
高槓桿期貨交易中的停損機制1. 停損設定必須符合價格擴散的統計特性,而不是任意的百分比門檻。在能源期貨價差等均值回歸市場中,最佳停損水準源自奧恩斯坦-烏倫貝克動力學下的首次退出時間分佈。 2. 固定的 1% 或 2% 停損忽略了波動性聚集和狀態轉變。對暖氣油/天然氣-油半小時資料的實證回溯測試表明,...
如何在重大經濟公告期間交易加密貨幣期貨
2026-06-12 22:50:44
市場波動模式1. Bitcoin 在減半公告或主要交易所上市等高流動性事件期間,單一 24 小時視窗內的價格波動通常超過 5%。 2. 過去 36 個月,山寨幣與 BTC 的相關性平均高於 0.78,顯示對 Bitcoin 方向性走勢的強烈依賴。 3. 期貨未平倉合約的飆漲常常先於急劇逆轉-尤其是當...
看所有文章














