-
Bitcoin
$119,169.1160
1.15% -
Ethereum
$3,388.8769
8.06% -
XRP
$3.0731
4.99% -
Tether USDt
$1.0004
0.02% -
BNB
$715.2755
3.36% -
Solana
$174.3933
5.80% -
USDC
$0.9999
-0.01% -
Dogecoin
$0.2171
7.90% -
TRON
$0.3103
3.38% -
Cardano
$0.7708
3.03% -
Hyperliquid
$47.1037
-2.62% -
Stellar
$0.4572
0.02% -
Sui
$3.9744
-2.33% -
Chainlink
$16.7611
3.94% -
Hedera
$0.2383
2.33% -
Bitcoin Cash
$502.0274
0.54% -
Avalanche
$22.8263
2.19% -
Shiba Inu
$0.0...01467
6.49% -
UNUS SED LEO
$8.8510
-0.58% -
Toncoin
$3.1822
2.73% -
Litecoin
$98.6569
1.78% -
Polkadot
$4.2070
2.57% -
Monero
$333.3491
-0.42% -
Pepe
$0.0...01380
6.68% -
Uniswap
$9.0730
-3.91% -
Bitget Token
$4.7975
5.53% -
Dai
$0.9999
-0.03% -
Ethena USDe
$1.0008
0.00% -
Aave
$326.4324
-0.57% -
Bittensor
$436.8763
-1.16%
スマートコントラクトの再発攻撃とは何ですか?
再発攻撃は、悪名高いDAOハックに見られるように、資金を排出するためにスマートコントラクトの再帰関数呼び出しを悪用します。
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) までご連絡ください。速やかに削除させていただきます。
- California dreamin 'web3:コインベース、リップル、ゴールデンステートの暗号抱擁
- 2025-07-17 10:30:12
- Coinbaseの「すべてのアプリ」ビジョン:Base App Unites Crypto、Social、およびPayments
- 2025-07-17 08:30:13
- アスター:米国の株式に関する永続的な契約でdefiに革命をもたらす
- 2025-07-17 08:30:13
- XRPの技術的アップトレンド:制度的勢いの波に乗る
- 2025-07-17 09:10:13
- XRPサージに乗る:精通した投資家のための長期戦略
- 2025-07-17 09:30:13
- 暗号価格チェック:XRPとソラナは、市場の不安の中でいくつかのグリットを見せます
- 2025-07-17 09:30:13
関連知識

コインマージド契約と硬い契約とは何ですか?
2025-07-15 18:36:13
Stablecoin-Margined契約とCoinmargined契約の違いを理解する暗号通貨デリバティブの世界では、マージンは、トレーダーが自分のポジションをどのように管理できるかを決定する上で重要な役割を果たします。トレーダーは、多くの場合、2つの主要なタイプの契約に遭遇します。スタブコインマ...

Bitcoin先物のボリュームプロファイルを分析する方法は?
2025-07-17 01:21:21
Bitcoin先物取引におけるボリュームプロファイルの理解ボリュームプロファイルは、さまざまな価格レベルでの取引量の分布を評価するためにトレーダーが使用する重要な分析ツールです。 Bitcoin先物では、主要なサポートとレジスタンスゾーンに関する洞察を提供し、トレーダーがほとんどの取引活動が歴史的に...

Bitcoin先物取引戦略をバックテストする方法は?
2025-07-15 11:35:36
Bitcoin先物取引の理解Bitcoin先物取引には、将来の価格と日付でBitcoinを売買する契約が含まれます。トレーダーはこれらの機器を使用して、価格の動きを推測したり、既存のポジションをヘッジしたりします。この文脈で戦略をバックテストすることは、実際の資本を危険にさらす前に、履歴データに取引...

初心者の先物トレーダーが犯した一般的な間違い
2025-07-17 07:49:58
リスクを理解せずに過度にレバレッジします初心者の先物トレーダーが犯した最も頻繁な間違いの1つは、彼らのポジションを覆すことです。先物取引には本質的にレバレッジが含まれます。これにより、トレーダーは比較的少量の資本を持つ大きな契約価値を制御できます。ただし、多くの新人は、このレバレッジが利益と損失の両...

取引の心理学Bitcoin契約
2025-07-13 02:50:00
Bitcoin先物取引の感情的なジェットコースターを理解するBitcoin契約取引は、特に先物の形で、トレーダーの心理的状態に大きな影響を与える可能性のある高レベルのボラティリティとレバレッジを導入します。実際のBitcoinを売買するスポット取引とは異なり、先物契約により、トレーダーは基礎となる資...

Bitcoin先物の取引計画を構築する方法は?
2025-07-17 08:42:35
Bitcoin先物取引の理解Bitcoin先物は、実際の資産を所有せずにBitcoinの将来の価格をトレーダーが推測できるようにする派生契約です。これらの機器は、機関投資家と小売投資家の両方が、職位をヘッジ、露出を活用したり、市場のボラティリティから利益を得たりするために広く使用されています。取引計...

コインマージド契約と硬い契約とは何ですか?
2025-07-15 18:36:13
Stablecoin-Margined契約とCoinmargined契約の違いを理解する暗号通貨デリバティブの世界では、マージンは、トレーダーが自分のポジションをどのように管理できるかを決定する上で重要な役割を果たします。トレーダーは、多くの場合、2つの主要なタイプの契約に遭遇します。スタブコインマ...

Bitcoin先物のボリュームプロファイルを分析する方法は?
2025-07-17 01:21:21
Bitcoin先物取引におけるボリュームプロファイルの理解ボリュームプロファイルは、さまざまな価格レベルでの取引量の分布を評価するためにトレーダーが使用する重要な分析ツールです。 Bitcoin先物では、主要なサポートとレジスタンスゾーンに関する洞察を提供し、トレーダーがほとんどの取引活動が歴史的に...

Bitcoin先物取引戦略をバックテストする方法は?
2025-07-15 11:35:36
Bitcoin先物取引の理解Bitcoin先物取引には、将来の価格と日付でBitcoinを売買する契約が含まれます。トレーダーはこれらの機器を使用して、価格の動きを推測したり、既存のポジションをヘッジしたりします。この文脈で戦略をバックテストすることは、実際の資本を危険にさらす前に、履歴データに取引...

初心者の先物トレーダーが犯した一般的な間違い
2025-07-17 07:49:58
リスクを理解せずに過度にレバレッジします初心者の先物トレーダーが犯した最も頻繁な間違いの1つは、彼らのポジションを覆すことです。先物取引には本質的にレバレッジが含まれます。これにより、トレーダーは比較的少量の資本を持つ大きな契約価値を制御できます。ただし、多くの新人は、このレバレッジが利益と損失の両...

取引の心理学Bitcoin契約
2025-07-13 02:50:00
Bitcoin先物取引の感情的なジェットコースターを理解するBitcoin契約取引は、特に先物の形で、トレーダーの心理的状態に大きな影響を与える可能性のある高レベルのボラティリティとレバレッジを導入します。実際のBitcoinを売買するスポット取引とは異なり、先物契約により、トレーダーは基礎となる資...

Bitcoin先物の取引計画を構築する方法は?
2025-07-17 08:42:35
Bitcoin先物取引の理解Bitcoin先物は、実際の資産を所有せずにBitcoinの将来の価格をトレーダーが推測できるようにする派生契約です。これらの機器は、機関投資家と小売投資家の両方が、職位をヘッジ、露出を活用したり、市場のボラティリティから利益を得たりするために広く使用されています。取引計...
すべての記事を見る
