-
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%
スマートコントラクトの再発攻撃とは何ですか?
A reentrancy attack exploits recursive function calls in smart contracts to drain funds, as seen in the infamous DAO hack.
2025/07/15 02:50
スマートコントラクトの基本を理解する
スマート契約は、コードに直接書かれた条件との自己実行契約です。 Ethereumのようなブロックチェーンプラットフォームで実行され、仲介者なしの当事者間の契約を自動的に実施します。これらの契約は展開されると不変です。つまり、コードに存在する脆弱性を展開後に変更することはできません。この不変性により、スマートコントラクトがライブになる前に、すべての可能なエクスプロイトから安全になることを保証することが重要になります。
そのようなエクスプロイトの1つは、暗号通貨のエコシステムの重大な損失の原因となっている再発攻撃です。この脆弱性がどのように機能するかを理解するには、スマートコントラクトが関数呼び出しを通じて外部アカウントやその他の契約とどのように相互作用するかを把握する必要があります。
再発攻撃とは何ですか?
悪意のある契約が、最初の実行が完了する前に、悪意のある契約が別の契約で脆弱な機能を繰り返し呼び出すと、再発攻撃が発生します。この再帰行動は、意図しない方法で資金を消耗させたり、状態変数を操作したりすることができます。
古典的な例には、エーテル転送を処理する契約が含まれます。関数が内部残高を更新する前にエーテルを外部アドレスに送信する場合、悪意のある契約は譲渡中に関数に再入力し、契約の資金を繰り返し排出できます。 2016年の悪名高いダオハックは、6,000万ドルのエーテル損失をもたらし、再発の脆弱性の結果でした。
再発攻撃は実際にどのように機能しますか?
再発攻撃のメカニズムをよりよく理解するには、次の単純化されたシナリオを検討してください。
- 契約には、ユーザーが堆積したエーテルを引き出すことができる
withdraw()関数があります。 - この関数は、最初に
call.value()を使用してユーザーにエーテルを送信し、ユーザーの残高をゼロに更新します。 - 悪意のある契約はユーザーとしてそれ自体を登録し、エーテルをターゲット契約に預けます。
-
withdraw()呼び出すと、ターゲット契約はエーテル転送を開始します。 - 転送中、悪意のある契約のフォールバック関数(自動的にトリガーされる)は、再び
withdraw()呼び出します。 - 残高はまだ更新されていないため、契約は、ユーザーがまだ利用可能な資金を持っており、より多くのエーテルを送信していると考えています。
- このループは、契約が排出されるかガスがなくなるまで続きます。
このプロセスは、契約内の運用順序を活用します。特に、州を更新する前にエーテルを送信します。
再発の脆弱性の種類
再発攻撃にはいくつかの形式があり、それぞれが契約ロジックのさまざまな側面を活用しています。
- 単一機能の再発:これは、単一の関数に外部呼び出しと状態の変更の両方が含まれる場合に発生します。州が更新される前の外部呼び出し中に攻撃者が再突入をトリガーします。
- クロス機能の再発:ここでは、複数の関数が状態変数を共有します。攻撃者は、最初の機能がまだ実行されている間に2番目の関数に再び入り、共有データを一貫して操作できません。
- DeLegateCallの再発:この高度なバリアントは、
delegatecallメカニズムを使用して、ある契約から別の契約のコンテキストでコードを実行します。慎重に処理されない場合、これは予期しない再発シナリオにつながる可能性があります。
各タイプでは、搾取を防ぐために慎重な監査と特定の緩和戦略が必要です。
再発攻撃を防ぐ方法
再発攻撃の防止には、契約設計のベストプラクティスを採用し、セキュリティツールを活用することが含まれます。
- Checks-effects-interactionsパターンを使用します。外部呼び出しを行う前に、常に契約の状態を更新してください。これにより、再入国が既存のバランスや状態を操作できないことが保証されます。
- REANTRANCY GOURDSを実装する:OpenzePpelinのようなライブラリは、Mutex変数を使用してリエントラントコールをブロックするリンステンスガード修飾子を提供します。
- 複雑な外部呼び出しを避ける:不明または信頼されていない契約との相互作用を最小限に抑えます。必要に応じて、コールバックが安全であり、任意のコードをトリガーしないようにしてください。
- プッシュオーバープッシュペイメントを使用してください:ユーザーに資金をプッシュする代わりに、引き出しを開始させます。これにより、再帰的な排出のリスクが減ります。
- 徹底的な監査を実施する:自動化されたツールと手動レビューを使用して、コードベースの潜在的な再発ベクターを検出します。
これらの戦略を適用することにより、開発者は再発攻撃を成功させる可能性を大幅に減らすことができます。
再発性のエクスプロイトの実世界の例
いくつかの有名な事件は、再発攻撃の壊滅的な影響を強調しています。
- The Dao Hack(2016) :最も有名なケースには、スマートコントラクトが再帰的な撤退を許可した分散型の自律組織が含まれていました。攻撃者はこれを悪用して、数百万相当のエーテルを排出しました。
- Fusion Network Attack(2021) :ハッカーは、プロトコルで機能を超えた再発バグを利用し、1,400万ドルの損失をもたらしました。
- Warp Finance Hack(2021) :複数の再発ポイントが異なる機能で悪用され、攻撃者が800万ドル近くの資産を排出できるようになりました。
これらの例は、コーディングプラクティスを確保するための厳密なテストと遵守の重要性を強調しています。
よくある質問
Q:エチレオム以外のブロックチェーンでは、再発攻撃が発生する可能性がありますか?はい、再発攻撃は、外部呼び出しおよび変動状態でスマートコントラクトをサポートするブロックチェーンプラットフォームに影響を与える可能性があります。 Ethereumは最も顕著なケースを見てきましたが、Binance Smart Chain、Solanaなどに同様の脆弱性が存在します。
Q:すべての外部呼び出しは危険ですか?いいえ、しかし、外部呼び出しは注意して扱う必要があります。危険は、重要な状態変数を更新する前に作成されると発生します。適切なコーディングパターンとセーフガードは、このリスクを軽減できます。
Q:契約の脆弱性について契約をテストするにはどうすればよいですか? SlithersやSecurifyなどの静的分析ツールを使用したり、手動コード監査を実行したり、BrownieやHardhatなどのフレームワークを使用して攻撃シナリオをシミュレートできたりできます。再発ガードを使用し、安全な開発慣行に従うことも役立ちます。
Q:フラッシュローン攻撃と再発攻撃の違いは何ですか?どちらもDefiプロトコルを活用できますが、フラッシュローン攻撃は、担保なしで大量の資本を借用し、同じ取引内で返済することに依存しています。再発攻撃は、契約状態を操作するために再帰的に呼び出して関数に焦点を当てています。ただし、一部の攻撃は両方の手法を組み合わせて、より大きな影響を与えます。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- Vitalik Buterin 氏、イーサリアムの L2 チェーンを再考: スケーラビリティとプライバシーの新時代?
- 2026-02-05 22:20:01
- Espresso のトケノミクスが明らかに、Coinbase のロードマップが関心を呼び起こし、最新のトケノミクスを考察
- 2026-02-05 22:15:01
- UBS、仮想通貨とビットコインを採用:トークン化に向けた戦略的転換
- 2026-02-05 22:25:01
- ビットコインの暴落がアルトコインのローテーションを引き起こす: 仮想通貨のボラティリティの中で投資を乗り切る
- 2026-02-05 22:20:01
- 暗号通貨の岐路: 大きな賭け、痛ましい損失、そして進化するビットコイン戦略
- 2026-02-05 22:15:01
- デジタル資産が大きくなる:ロンドンフォーラムがステーブルコインの急増と制度的猛攻撃を称賛
- 2026-02-05 22:10:02
関連知識
感情と先物における「リベンジ取引」を管理する方法?
2026-02-05 00:19:32
先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...
先物エントリーにキャンドルクローズ確認を使用するにはどうすればよいですか?
2026-02-05 16:20:22
ローソク足のクローズ確認を理解する1. ローソク足の終値確認は、ローソク足の最終価格が事前定義されたレベルを超えて安定したときに発生し、トレンド継続または反転の可能性を示します。 2. トレーダーは、日中のウィックや始値ではなく、終値に依存します。これは、終値がその時間間隔での市場全体のコンセンサス...
恐怖と貪欲指数を使用して市場センチメントを分析するにはどうすればよいですか?
2026-02-05 07:40:21
恐怖と貪欲の指数を理解する1. 恐怖と貪欲指数は、仮想通貨投資家の間で蔓延している感情状態を定量化するために設計された複合指標です。ボラティリティ、市場の勢い、ソーシャルメディア活動、調査結果、Bitcoin の優位性、検索傾向など、複数のソースからデータを集約します。 2. スコア 0 は極度の恐...
フィッシング対策コードを使用して先物アカウントを保護するにはどうすればよいですか?
2026-02-05 20:40:18
仮想通貨先物取引におけるフィッシング対策コードを理解する1. フィッシング対策コードは、ユーザーのログイン セッションとトランザクション リクエストを認証するために先物取引所によって生成される固有の英数字の文字列です。 2. これらのコードは、標準の 2 要素認証を超える追加の検証層として機能し、特...
出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?
2026-02-04 23:39:35
ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...
ヘッジのために初めての暗号オプション取引を設定するにはどうすればよいですか?
2026-02-05 17:59:32
市場のボラティリティパターン1. Bitcoin やイーサリアムを含む主要な暗号通貨では、24 時間以内に 15% を超える価格変動が定期的に発生します。 2. 取引所ベースのオーダーブックの不均衡は、特に週末やアジアの取引時間などの流動性の低い期間に、連鎖的な清算を引き起こすことがよくあります。 ...
感情と先物における「リベンジ取引」を管理する方法?
2026-02-05 00:19:32
先物市場における感情的なトリガーを理解する1. 市場のボラティリティは心理状態に直接影響を与え、急速な価格変動に基づいて恐怖や高揚感を増幅させることがよくあります。 2. 喪失は脳の脅威反応システムを活性化し、系統的な分析ではなく衝動的な決定を引き起こします。 3. ソーシャルメディアのフィードやグ...
先物エントリーにキャンドルクローズ確認を使用するにはどうすればよいですか?
2026-02-05 16:20:22
ローソク足のクローズ確認を理解する1. ローソク足の終値確認は、ローソク足の最終価格が事前定義されたレベルを超えて安定したときに発生し、トレンド継続または反転の可能性を示します。 2. トレーダーは、日中のウィックや始値ではなく、終値に依存します。これは、終値がその時間間隔での市場全体のコンセンサス...
恐怖と貪欲指数を使用して市場センチメントを分析するにはどうすればよいですか?
2026-02-05 07:40:21
恐怖と貪欲の指数を理解する1. 恐怖と貪欲指数は、仮想通貨投資家の間で蔓延している感情状態を定量化するために設計された複合指標です。ボラティリティ、市場の勢い、ソーシャルメディア活動、調査結果、Bitcoin の優位性、検索傾向など、複数のソースからデータを集約します。 2. スコア 0 は極度の恐...
フィッシング対策コードを使用して先物アカウントを保護するにはどうすればよいですか?
2026-02-05 20:40:18
仮想通貨先物取引におけるフィッシング対策コードを理解する1. フィッシング対策コードは、ユーザーのログイン セッションとトランザクション リクエストを認証するために先物取引所によって生成される固有の英数字の文字列です。 2. これらのコードは、標準の 2 要素認証を超える追加の検証層として機能し、特...
出来高プロファイルを使用して主要な先物エントリーレベルを見つけるにはどうすればよいですか?
2026-02-04 23:39:35
ボリュームプロファイル構造の理解1. 出来高プロファイルは、定義された期間にわたる特定の価格レベルでの取引高の分布を表示し、チャート上に水平方向のヒストグラムを形成します。 2. コントロールポイント (POC) は、出来高集中が最も高い価格レベルを表し、多くの場合、価格反転の磁石として機能します。...
ヘッジのために初めての暗号オプション取引を設定するにはどうすればよいですか?
2026-02-05 17:59:32
市場のボラティリティパターン1. Bitcoin やイーサリアムを含む主要な暗号通貨では、24 時間以内に 15% を超える価格変動が定期的に発生します。 2. 取引所ベースのオーダーブックの不均衡は、特に週末やアジアの取引時間などの流動性の低い期間に、連鎖的な清算を引き起こすことがよくあります。 ...
すべての記事を見る














