-
Bitcoin
$118300
0.33% -
Ethereum
$3817
2.08% -
XRP
$3.537
1.37% -
Tether USDt
$1.000
-0.03% -
BNB
$772.1
3.39% -
Solana
$191.1
5.59% -
USDC
$0.9999
0.00% -
Dogecoin
$0.2730
8.18% -
Cardano
$0.9174
7.84% -
TRON
$0.3149
-0.94% -
Hyperliquid
$47.23
3.65% -
Stellar
$0.4855
4.05% -
Sui
$4.031
1.38% -
Chainlink
$20.04
4.24% -
Hedera
$0.2852
5.13% -
Avalanche
$25.97
4.21% -
Bitcoin Cash
$530.2
-0.84% -
Shiba Inu
$0.00001560
3.45% -
Litecoin
$117.4
1.08% -
Toncoin
$3.361
2.96% -
UNUS SED LEO
$8.991
-0.03% -
Polkadot
$4.590
2.68% -
Uniswap
$10.56
-0.54% -
Ethena USDe
$1.001
-0.02% -
Monero
$327.9
1.24% -
Pepe
$0.00001410
2.19% -
Bitget Token
$4.973
-0.63% -
Dai
$0.9999
0.00% -
Aave
$330.4
1.29% -
Bittensor
$428.0
0.13%
堅牢性の再所属を防ぐ方法は?
堅牢性の再発は、外部呼び出しが悪意のある契約が同じ機能を再帰的に実行し、潜在的に排出された資金または腐敗状態を再帰的に実行することを許可する場合に発生します。
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) までご連絡ください。速やかに削除させていただきます。
- ビットコイン、トランプメディア、および買収:ニューヨークの視点
- 2025-07-22 06:30:12
- ベンチャーキャピタル、Crypto Treasuries、およびEthena(ENA):ニューヨークの視点
- 2025-07-22 06:50:13
- ソラナ:ブロックアセンブリマーケットプレイスで分散型ナスダックを構築しますか?
- 2025-07-22 06:30:12
- Jito、Bam、Solana Mev:ブロックスペースの新しい時代?
- 2025-07-22 06:50:13
- Raydium、Crypto Dayroll、およびTransformation:Fintechの新しい時代
- 2025-07-22 07:30:12
- Arctic Pablo Coin Presale:2025年のミームコインチャンス?
- 2025-07-22 07:35:12
関連知識

メーカーとテイカー料金とは何ですか?
2025-07-19 01:14:23
暗号通貨交換料金の基本を理解する暗号通貨取引の世界では、メーカーとテイカーの手数料は、すべてのトレーダーが理解すべき基本的な概念です。これらの料金は、配置する注文の種類に基づいてユーザーとの交換によって請求されます。メーカーとテイカーの手数料の区別は、取引コストで支払う金額に影響を与え、取引戦略に影...

暗号先物取引口座を保護する方法は?
2025-07-21 23:42:26
暗号先物取引のリスクを理解する暗号先物取引には、市場のボラティリティとレバレッジによる重大なリスクが含まれます。取引口座は、慎重に管理されていなければ、ハッキング、フィッシング、またはマージンの清算にさらされる可能性があります。これらのリスクを理解することは、資産を確保するための最初のステップです。...

Bitcoin先物は詐欺を取引していますか?
2025-07-22 01:42:18
Bitcoin先物取引の理解Bitcoin先物取引とは、Bitcoinの将来の価格から価値を引き出す契約を売買するプロセスを指します。これらの契約により、トレーダーは、基礎となる資産を実際に所有することなく、Bitcoinの価格移動について推測することができます。概念自体は合法ですが、多くの人がBi...

Bitcoin先物データをCMEから分析する方法は?
2025-07-19 17:22:11
CMEでのBitcoin先物の理解Bitcoin CME Group(Chicago Mercantile Exchange)の先物は、投資家が基礎となる資産を所有せずにBitcoinの将来の価格を推測できる規制された金融商品を表しています。これらの先物契約は標準化され、集中交換で取引されているため...

Bitcoin契約の高度な注文タイプ
2025-07-21 13:14:41
Bitcoin契約の高度な注文タイプの理解Bitcoin先物取引の世界では、高度な注文タイプは、リスクの管理、戦略の自動化、実行効率の向上に重要な役割を果たします。これらの注文タイプは、基本的な市場を超えて注文を制限し、トレーダーがポジションに入るか終了するための条件付き指示を設定できるようにします...

暗号先物取引における一般的な間違い
2025-07-20 21:56:36
リスク管理なしの過剰評価Crypto先物取引で最も一般的な間違いの1つは、過剰なものです。トレーダーはしばしば、高いレバレッジを使用すると利益が大幅に増加すると考えていますが、これは大きな損失のリスクも掛けています。ストップロスの注文を設定したり、ポジションサイジングを無視したりすると、アカウント全...

メーカーとテイカー料金とは何ですか?
2025-07-19 01:14:23
暗号通貨交換料金の基本を理解する暗号通貨取引の世界では、メーカーとテイカーの手数料は、すべてのトレーダーが理解すべき基本的な概念です。これらの料金は、配置する注文の種類に基づいてユーザーとの交換によって請求されます。メーカーとテイカーの手数料の区別は、取引コストで支払う金額に影響を与え、取引戦略に影...

暗号先物取引口座を保護する方法は?
2025-07-21 23:42:26
暗号先物取引のリスクを理解する暗号先物取引には、市場のボラティリティとレバレッジによる重大なリスクが含まれます。取引口座は、慎重に管理されていなければ、ハッキング、フィッシング、またはマージンの清算にさらされる可能性があります。これらのリスクを理解することは、資産を確保するための最初のステップです。...

Bitcoin先物は詐欺を取引していますか?
2025-07-22 01:42:18
Bitcoin先物取引の理解Bitcoin先物取引とは、Bitcoinの将来の価格から価値を引き出す契約を売買するプロセスを指します。これらの契約により、トレーダーは、基礎となる資産を実際に所有することなく、Bitcoinの価格移動について推測することができます。概念自体は合法ですが、多くの人がBi...

Bitcoin先物データをCMEから分析する方法は?
2025-07-19 17:22:11
CMEでのBitcoin先物の理解Bitcoin CME Group(Chicago Mercantile Exchange)の先物は、投資家が基礎となる資産を所有せずにBitcoinの将来の価格を推測できる規制された金融商品を表しています。これらの先物契約は標準化され、集中交換で取引されているため...

Bitcoin契約の高度な注文タイプ
2025-07-21 13:14:41
Bitcoin契約の高度な注文タイプの理解Bitcoin先物取引の世界では、高度な注文タイプは、リスクの管理、戦略の自動化、実行効率の向上に重要な役割を果たします。これらの注文タイプは、基本的な市場を超えて注文を制限し、トレーダーがポジションに入るか終了するための条件付き指示を設定できるようにします...

暗号先物取引における一般的な間違い
2025-07-20 21:56:36
リスク管理なしの過剰評価Crypto先物取引で最も一般的な間違いの1つは、過剰なものです。トレーダーはしばしば、高いレバレッジを使用すると利益が大幅に増加すると考えていますが、これは大きな損失のリスクも掛けています。ストップロスの注文を設定したり、ポジションサイジングを無視したりすると、アカウント全...
すべての記事を見る
