-
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%
リエントランシー攻撃とは何ですか?また、スマートコントラクトはそれをどのように防御できますか?
Re-entrancy attacks exploit unchecked external calls in smart contracts, allowing attackers to recursively withdraw funds before state updates, as seen in the $60M DAO hack.
2025/11/13 03:40
スマートコントラクトにおけるリエントランシー攻撃を理解する
1. 再入攻撃は、最初の実行が完了する前に、悪意のあるコントラクトが別のコントラクトの脆弱な機能を繰り返しコールバックするときに発生します。このエクスプロイトは、状態の変更と外部呼び出しが実行される順序を利用します。
2. 最も悪名高い例は、2016 年の DAO ハッキングです。このハッキングでは、攻撃者がイーサを送信する前に残高を更新できなかった契約から資金を再帰的に引き出し、6,000 万ドル以上を流出させました。
3. これらの攻撃は通常、重要な状態変数を矛盾した状態に保持しながら、信頼できないコントラクトへの外部呼び出しを行う関数をターゲットとします。
4. 再帰呼び出し中に、攻撃者のフォールバックまたは受信関数が同じ引き出しロジックを再度トリガーし、アクセス制御や残高チェックを事実上バイパスします。
5. 中心的な脆弱性は、チェック効果相互作用パターンに違反することにあります。このパターンでは、実行中の操作を防ぐために、状態の変更は常に外部呼び出しよりも前に行われる必要があります。
Solidity における一般的な脆弱なパターン
1. 最初に内部アカウンティングを更新せずに、ユーザーが制御するアドレスに Ether またはトークンを送信する機能は、再入可能性の主なターゲットです。
2. ネイティブ Ether 転送によるコールなどの低レベルのコールを使用するコントラクトは、残りのすべてのガスを転送し、複雑なコールバック ロジックが可能になるため、特にリスクにさらされます。
3. 呼び出し後の検証に依存するロジックは、呼び出し自体が再帰エントリをトリガーすると失敗し、損傷が発生するまでそれらのチェックが無効になります。
4. たとえ子コントラクトが安全であるように見えても、親コントラクトが適切な保護を強制しない場合、継承構造により意図せずに機能が公開される可能性があります。
5. デリゲートコール メカニズムが共有ストレージ レイアウトを通じて状態の破損を許可する場合、ライブラリまたはプロキシ パターンによって脆弱性が伝播する可能性があります。
効果的な防御メカニズム
1. Checks-Effects-Interactionsパターンを厳密に実装します。常に入力を検証し、状態変数を更新してから、外部呼び出しを続行します。
2. OpenZeppelin の ReentrancyGuard などの確立されたライブラリの再入ガードを使用します。このガードは、ミューテックス ロックを使用して再帰エントリをブロックします。
3.電話の代わりに転送または送信を介して資金を転送することを好みます。これらの方法はガス転送を制限し、攻撃対象領域を減らすためです。
4. 自動的に送金されるのではなく、ユーザーが資金を請求するプルオーバープッシュ支払いモデルを採用し、アウトバウンド コールのリスクを排除します。
5. 開発中に厳密な静的分析ツールと正式な検証を適用して、展開前に潜在的な再帰パスを検出します。
よくある質問
再入シナリオにおいてフォールバック機能が危険になるのはなぜですか?フォールバック関数は、呼び出し側コントラクトのビジネス関数を再度呼び出すロジックが含まれている場合、危険になります。外部呼び出しを行う前に元のコントラクトの状態が更新されていない場合、この再帰トリガーによって古い残高やアクセス許可が悪用される可能性があります。
複数の契約対話にわたって再入が発生する可能性はありますか?はい、同じコントラクト内の異なる機能が適切な同期を行わずに共有状態にアクセスすると、機能間の再入が可能になります。攻撃者は、外部から呼び出す 1 つの関数をトリガーし、状態が更新される前にフォールバックを使用して 2 番目の脆弱な関数に入る可能性があります。
非イーサ契約は再入の影響を受けませんか?いいえ、ERC-20 転送を処理するトークン コントラクトも悪用される可能性があります。トークン転送が受信側フック (承認 + コールバックなど) をトリガーし、受信コントラクトが転送中に送信側の状態を操作する場合、同様の再帰的エクスプロイトが出現します。
コンパイラのアップグレードは再入を軽減するのにどのように役立ちますか? Solidity の新しいバージョンには、より安全なデフォルトと既知のアンチパターンに対する警告が含まれています。たとえば、明示的な可視性指定子と改善されたガソリン給金ルールにより、意図しない動作が減少します。ただし、コンパイラ機能だけでは、アーキテクチャ上の規律を必要とする論理的欠陥を排除することはできません。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- ビットコイン、eCash フォーク、Airdrop のダイナミクス: 暗号通貨の最新の論争を深く掘り下げる
- 2026-05-03 12:55:01
- コンセンサス 2026 マイアミ: Web3、ブロックチェーン、暗号通貨、NFT、メタバース、カンファレンス、5 月 5 日 — ウォール街とデジタル フロンティアが出会う場所
- 2026-05-02 12:45:01
- FRBが金利を据え置き、地政学的な緊張の中、ビットコイン価格の下落を引き起こす
- 2026-05-01 06:45:01
- ビットコインマイナーが送電網を電化:オハイオ州のガス工場買収がデジタルゴールドの新時代を加速
- 2026-05-01 00:45:01
- MegaETH の MEGA トークンがビッグアップルに到達: リアルタイム ブロックチェーンの新しいパフォーマンス ベンチマークを設定
- 2026-05-01 00:55:01
- ソラナの滑りやすい坂道: 価格予測は抵抗力の損失とさらなる下落の可能性を示している
- 2026-05-01 06:45:01
関連知識
モジュラーブロックチェーンとは何ですか? (建築の基礎)
2026-04-16 12:39:57
モジュラーブロックチェーンとは何ですか? 1. モジュラーブロックチェーンは、コアブロックチェーン機能を個別の相互運用可能なレイヤーに意図的に分離するアーキテクチャパラダイムです。 2. 実行、コンセンサス、データの可用性、決済がすべて同じチェーン上で行われるモノリシック チェーンとは異なり、モジュ...
偽の仮想通貨ウェブサイトを見分ける方法は? (不正検知)
2026-04-16 13:19:40
ドメイン名分析1. 正規の暗号通貨プラットフォームは、クリーンで覚えやすいドメイン名を使用します。多くの場合、標準的なラテン文字でブランド名やコア サービスが組み込まれています。 2. 偽サイトは、「o」を「0」に、「l」を「1」に、「I」を「|」に置き換えるなど、視覚的に欺瞞的な置換を頻繁に展開し...
ブロックチェーンにおけるオラクルとは何ですか? (外部データ)
2026-04-11 03:59:39
定義とコア機能1. ブロックチェーンにおける Oracle は、スマート コントラクトに外部データを提供する信頼できるサードパーティ サービスです。 2. オンチェーン ロジックと、API、データベース、Web フィード、IoT デバイスなどのオフチェーン情報ソースの間のブリッジとして機能します。 ...
トランザクション ハッシュ (TxID) を解釈するにはどうすればよいですか? (支払証明書)
2026-04-10 23:19:44
トランザクションハッシュとは何ですか? 1. TxID またはトランザクション ID とも呼ばれるトランザクション ハッシュは、ブロックチェーン トランザクションのシリアル化されたデータに暗号化ハッシュ関数を適用することによって生成される一意の英数字の文字列です。 2. 各トランザクションの不変のフ...
ゲームファイとは何ですか? (プレイ・トゥ・アーンの基本)
2026-04-13 11:00:17
定義とコアアーキテクチャ1. GameFi はゲームと金融の融合を表し、完全にパブリック ブロックチェーン インフラストラクチャ上に構築されています。 2. ステーキング、流動性供給、イールドファーミング、ガバナンス投票などの分散型金融プリミティブをインタラクティブなゲームメカニズムに直接埋め込みま...
NFTマーケットプレイスの使い方は? (売買)
2026-04-19 12:40:30
Web3 ウォレットのセットアップ1. 公式ブラウザ拡張機能またはモバイルアプリ経由で MetaMask または Trust Wallet をインストールします。 2. 新しいウォレットを作成し、12 単語のリカバリ フレーズをオフラインで安全に保存します。 3. ガス料金をカバーするために、ネイテ...
モジュラーブロックチェーンとは何ですか? (建築の基礎)
2026-04-16 12:39:57
モジュラーブロックチェーンとは何ですか? 1. モジュラーブロックチェーンは、コアブロックチェーン機能を個別の相互運用可能なレイヤーに意図的に分離するアーキテクチャパラダイムです。 2. 実行、コンセンサス、データの可用性、決済がすべて同じチェーン上で行われるモノリシック チェーンとは異なり、モジュ...
偽の仮想通貨ウェブサイトを見分ける方法は? (不正検知)
2026-04-16 13:19:40
ドメイン名分析1. 正規の暗号通貨プラットフォームは、クリーンで覚えやすいドメイン名を使用します。多くの場合、標準的なラテン文字でブランド名やコア サービスが組み込まれています。 2. 偽サイトは、「o」を「0」に、「l」を「1」に、「I」を「|」に置き換えるなど、視覚的に欺瞞的な置換を頻繁に展開し...
ブロックチェーンにおけるオラクルとは何ですか? (外部データ)
2026-04-11 03:59:39
定義とコア機能1. ブロックチェーンにおける Oracle は、スマート コントラクトに外部データを提供する信頼できるサードパーティ サービスです。 2. オンチェーン ロジックと、API、データベース、Web フィード、IoT デバイスなどのオフチェーン情報ソースの間のブリッジとして機能します。 ...
トランザクション ハッシュ (TxID) を解釈するにはどうすればよいですか? (支払証明書)
2026-04-10 23:19:44
トランザクションハッシュとは何ですか? 1. TxID またはトランザクション ID とも呼ばれるトランザクション ハッシュは、ブロックチェーン トランザクションのシリアル化されたデータに暗号化ハッシュ関数を適用することによって生成される一意の英数字の文字列です。 2. 各トランザクションの不変のフ...
ゲームファイとは何ですか? (プレイ・トゥ・アーンの基本)
2026-04-13 11:00:17
定義とコアアーキテクチャ1. GameFi はゲームと金融の融合を表し、完全にパブリック ブロックチェーン インフラストラクチャ上に構築されています。 2. ステーキング、流動性供給、イールドファーミング、ガバナンス投票などの分散型金融プリミティブをインタラクティブなゲームメカニズムに直接埋め込みま...
NFTマーケットプレイスの使い方は? (売買)
2026-04-19 12:40:30
Web3 ウォレットのセットアップ1. 公式ブラウザ拡張機能またはモバイルアプリ経由で MetaMask または Trust Wallet をインストールします。 2. 新しいウォレットを作成し、12 単語のリカバリ フレーズをオフラインで安全に保存します。 3. ガス料金をカバーするために、ネイテ...
すべての記事を見る














