-
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
堅実さでの再所属を理解する
再発は、内部状態の変更を完了する前に関数が信頼されていない契約に外部呼び出しを行うときに発生するSolidity Smart Contractsの重大なセキュリティの脆弱性です。これにより、外部契約は元の機能に再帰的に呼び戻すことができ、潜在的に資金を排出したり、契約のロジックを破壊したりすることができます。
2016年の悪名高いダオハックは、再発をどのように活用できるかの代表的な例でした。攻撃者は、契約がバランスを更新する前に、悪意のあるフォールバック関数を使用して引き出しを繰り返し引き起こし、数百万のエーテルを失いました。
このような脆弱性を防ぐために、開発者は外部呼び出しを確保するベストプラクティスと設計パターンを実装し、外部の相互作用の前に状態の変更が発生するようにする必要があります。
Checks-effects-interactionsパターンを使用します
再発を防ぐ最も効果的な方法の1つは、チェック効果のインタラクションパターンに従うことです。このパターンにより、外部呼び出しが実行される前に、すべての内部状態の変更が行われます。
- チェック:入力と条件を検証します。
- 効果:契約の状態変数を更新します。
- 相互作用:外部契約を呼び出すか、エーテルを送信します。
この命令を順守することにより、再発の試みが発生したとしても、内部状態がすでに更新されており、二重の支出または不正なバランスアクセスを防止していることを確認します。
たとえば、単純な引き出し関数を考えてみましょう。
function withdraw(uint amount) public {require(balances[msg.sender] >= amount); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success);
}
この場合、バランスは外部呼び出しの前に更新され、再発から安全になります。
Mutexロックを実装します
再発を防ぐためのもう1つの効果的な方法は、 Mutex Lockを使用することです。これは、実行中の再発を防ぐ状態変数です。
簡単な例には、ブールフラグを使用して再入国をブロックすることが含まれます。
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のReentrancyGuardを使用します
Mutexロジックを手動で実装する代わりに、開発者は、安全でテストされたソリューションを提供するOpenzePpelinが提供するReentrancyGuard契約を使用できます。
ReentrancyGuardを使用するには:
- 契約のインポート:
import '@openzeppelin/contracts/security/ReentrancyGuard.sol'; - あなたの契約でそれから継承する:
contract MyContract is ReentrancyGuard -
nonReentrant修飾子を再発の影響を受けやすい関数に適用します。
pragma solidity ^0.8.0;'@openzeppelin/contracts/security/reintrancyguard.sol'をインポートします。契約securewithdrawalはreintrancyguardです{
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'); }}
このアプローチは、ミューテックスの取り扱いの複雑さを抽象化し、バグを導入するリスクを減らし、多くの開発者にとって好ましい方法になります。
生の通話を避け、安全に転送してください
Solidityでは、 address.call{value: ...}('')を使用すると、 transfer()またはsend()よりも柔軟性がありますが、ガス制限も削除され、再発に対して脆弱になります。
-
transfer()およびsend()は2300ガスのみを転送します。これは意味のある実行には不十分であり、それにより再発を防ぎます。 - ただし、
call()は利用可能なすべてのガスを転送し、攻撃者がフォールバック中に複雑な悪意のあるロジックを実行したり、機能を受け取ったりすることができます。
これを軽減するには:
- 単純なエーテル転送の場合は
transfer()またはsend()選択します。 -
call()を使用する必要がある場合は、コールの前に状態の変更が発生し、その再発ガードが配置されていることを確認してください。
FAQ:よくある質問
Q:堅実さの再発攻撃とは何ですか? A:再発攻撃は、外部契約が処刑を完了する前に呼び出し関数に呼び戻し、しばしば許可されていないファンドの撤回または州の腐敗につながるときに発生します。
Q:openzeppelinのReintrancyguardを使用せずに再所属を防ぐことはできますか? A:はい、チェックエフェクトインタラクションパターンを手動で実装するか、ミューテックスロックを使用して関数実行中の再発をブロックします。
Q:現代の堅牢性バージョンでaddress.transfer()を使用しても安全ですか? A: transfer()がガスを制限し、再発を防ぎますが、受信者契約がガスがなくなった場合、予期せずに失敗する可能性があります。単純な転送の場合call()よりも安全であると考えられています。
Q:すべての外部呼び出しは、堅牢性のすべての再所属に対して脆弱ですか? A:すべてではありませんが、ユーザー制御契約への外部呼び出しは潜在的なベクトルになる可能性があります。脆弱性は、状態がコール自体ではなく、外部呼び出しに続くと発生します。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- アナリストの警告と市場センチメントの変化の中でビットコインが下落
- 2026-02-05 09:40:02
- ジョージア州兄弟、COAMの入念な賭博詐欺計画で懲役20年の判決
- 2026-02-05 09:45:01
- MicroStrategy の株式損失:仮想通貨のボラティリティの中で年金基金は 60% の暴落に直面
- 2026-02-05 10:55:01
- 第 5 回スーパーボウル: テディ スイム、グリーン デイ、2026 年の祭典のレガシー トス セット
- 2026-02-05 07:20:02
- ファンタジー フットボール プレミア リーグ ラウンド 25: チームのパフォーマンスを最適化するための主要選手の選択、ヒント、アドバイス
- 2026-02-05 07:15:02
- Remittix、寛大な 300% ボーナスを提供する PayFi プラットフォームを開始し、投資家の興奮を後押し
- 2026-02-05 07:05:01
関連知識
感情と先物における「リベンジ取引」を管理する方法?
2026-02-05 00:19:32
先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...
恐怖と貪欲指数を使用して市場センチメントを分析するにはどうすればよいですか?
2026-02-05 07:40:21
恐怖と貪欲の指数を理解する1. 恐怖と貪欲指数は、仮想通貨投資家の間で蔓延している感情状態を定量化するために設計された複合指標です。ボラティリティ、市場の勢い、ソーシャルメディア活動、調査結果、Bitcoin の優位性、検索傾向など、複数のソースからデータを集約します。 2. スコア 0 は極度の恐...
出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?
2026-02-04 23:39:35
ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...
Bitcoin 先物を 100 倍のレバレッジで取引するにはどうすればよいですか? (ハイリスクセットアップ)
2026-02-05 11:00:08
Bitcoin 先物メカニズムを理解する1. Bitcoin 先物契約は、規制対象またはオフショアのデリバティブ取引所で取引される、将来の所定の価格および日付で BTC を売買する契約を表します。 2. スポット取引とは異なり、先物ではトレーダーはロングポジションとショートポジションを通じて価格の上...
クロスマージン取引を利用して資本効率を最大化するには?
2026-02-05 00:40:24
クロスマージン取引の基礎1. クロスマージン取引により、トレーダーは口座残高全体を複数の市場で同時にオープンポジションの担保として使用できます。 2. 各ポジションに専用のマージンプールがある独立マージンとは異なり、クロスマージンはウォレットに保持されているすべての資産から資本を動的に割り当てます。...
主要なニュースイベント中に仮想通貨契約を取引するにはどうすればよいですか? (CPI/FOMC)
2026-02-05 09:59:37
マクロデータリリースに対する市場の敏感度を理解する1. 仮想通貨先物市場は、金融政策の期待と直接関係しているため、米国の CPI および FOMC の発表中に顕著な変動を示します。 2. Bitcoin とイーサリアムの永久契約は、公式データが低下する数分前に資金調達レートを 50 ~ 200 ベー...
感情と先物における「リベンジ取引」を管理する方法?
2026-02-05 00:19:32
先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...
恐怖と貪欲指数を使用して市場センチメントを分析するにはどうすればよいですか?
2026-02-05 07:40:21
恐怖と貪欲の指数を理解する1. 恐怖と貪欲指数は、仮想通貨投資家の間で蔓延している感情状態を定量化するために設計された複合指標です。ボラティリティ、市場の勢い、ソーシャルメディア活動、調査結果、Bitcoin の優位性、検索傾向など、複数のソースからデータを集約します。 2. スコア 0 は極度の恐...
出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?
2026-02-04 23:39:35
ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...
Bitcoin 先物を 100 倍のレバレッジで取引するにはどうすればよいですか? (ハイリスクセットアップ)
2026-02-05 11:00:08
Bitcoin 先物メカニズムを理解する1. Bitcoin 先物契約は、規制対象またはオフショアのデリバティブ取引所で取引される、将来の所定の価格および日付で BTC を売買する契約を表します。 2. スポット取引とは異なり、先物ではトレーダーはロングポジションとショートポジションを通じて価格の上...
クロスマージン取引を利用して資本効率を最大化するには?
2026-02-05 00:40:24
クロスマージン取引の基礎1. クロスマージン取引により、トレーダーは口座残高全体を複数の市場で同時にオープンポジションの担保として使用できます。 2. 各ポジションに専用のマージンプールがある独立マージンとは異なり、クロスマージンはウォレットに保持されているすべての資産から資本を動的に割り当てます。...
主要なニュースイベント中に仮想通貨契約を取引するにはどうすればよいですか? (CPI/FOMC)
2026-02-05 09:59:37
マクロデータリリースに対する市場の敏感度を理解する1. 仮想通貨先物市場は、金融政策の期待と直接関係しているため、米国の CPI および FOMC の発表中に顕著な変動を示します。 2. Bitcoin とイーサリアムの永久契約は、公式データが低下する数分前に資金調達レートを 50 ~ 200 ベー...
すべての記事を見る














