-
Bitcoin
$117,631.7644
1.41% -
Ethereum
$2,961.0817
0.41% -
XRP
$2.8054
10.19% -
Tether USDt
$1.0003
0.03% -
BNB
$694.5065
0.64% -
Solana
$163.5558
-0.60% -
USDC
$0.9999
0.01% -
Dogecoin
$0.2025
3.64% -
TRON
$0.3028
2.78% -
Cardano
$0.7277
6.87% -
Hyperliquid
$46.2480
4.91% -
Stellar
$0.3855
27.41% -
Sui
$3.4324
-1.23% -
Bitcoin Cash
$531.9904
2.62% -
Chainlink
$15.3821
0.45% -
Avalanche
$20.8606
0.30% -
Hedera
$0.1982
2.33% -
UNUS SED LEO
$9.0857
0.57% -
Shiba Inu
$0.0...01336
-0.22% -
Toncoin
$2.9839
1.16% -
Litecoin
$94.9247
-0.17% -
Polkadot
$3.9625
1.93% -
Monero
$333.8076
1.12% -
Uniswap
$8.7979
4.58% -
Dai
$1.0000
0.01% -
Ethena USDe
$1.0006
0.00% -
Bitget Token
$4.4999
-1.20% -
Pepe
$0.0...01240
-0.29% -
Aave
$299.5052
-2.39% -
Bittensor
$398.0101
5.98%
プロキシ契約とは何ですか?また、アップグレード性をどのように可能にしますか?
プロキシ契約により、「DeLegateCall」を使用して、機能を更新しながら状態を維持するために、ロジックをストレージから分離することにより、スマートコントラクトのアップグレードが可能になります。
2025/07/10 19:42

スマート契約開発におけるプロキシ契約の理解
ブロックチェーンとスマートコントラクトの開発の世界では、プロキシ契約が重要な設計パターンとして浮上しています。展開が一度不可能な従来のスマート契約とは異なり、プロキシ契約は、契約全体を再展開することなく変更とアップグレードを実装するための構造化されたメカニズムを提供します。この柔軟性は、展開されたコードを直接変更できないイーサリアムのような環境で特に重要です。プロキシ契約は、ユーザーとアプリケーションの実際のロジックの間の仲介者として機能し、開発者が時間の経過とともに機能を更新できるようにします。
プロキシ契約の仕組み:技術的な概要
その中核では、プロキシ契約は、実装契約と呼ばれる別の契約を中心にファサードまたはラッパーとして機能します。ユーザーがプロキシと対話すると、 delegatecall
opcodeを使用して機能コールを実装契約に転送します。このオペコードは、ロジックが他の場所に存在していても、実行のコンテキスト(ストレージや送信者アドレスなど)がプロキシの状態と一致し続けることを保証します。
- プロキシは契約の状態を維持します。
- 実装契約には、ビジネスロジックが含まれています。
- ユーザーからの関数呼び出しは、プロキシを介して現在の実装にルーティングされます。
この分離により、プロキシアドレスに結び付けられたすべての既存のデータとインタラクションを保存しながら、実装の更新が可能になります。
アップグレード可能性を有効にする上でのDelegateCallの役割
プロキシ契約のアップグレード可能性を可能にする主要な技術的機能は、 delegatecall
メカニズムです。 Solidityでは、 delegatecall
では、1つの契約が別の契約からコードを実行しながら、発信者のストレージ、価値、およびコンテキストを維持できます。これは、プロキシ契約がdelegatecall
を使用して実装契約で機能を呼び出す場合、実行中に行われた変更は実装ではなくプロキシのストレージに影響することを意味します。
この動作は、次のために不可欠です。
- アップグレード後もデータが持続することを保証します。
- これは、将来の変更に必要なストレージからロジックを切り離します。
delegatecall
がなければ、アップグレードでは契約とその関連データの両方を再配置する必要があり、潜在的な矛盾と情報の損失につながります。
実際に使用されるプロキシパターンの種類
いくつかのプロキシパターンがイーサリアムエコシステム内に存在し、それぞれがさまざまな複雑さと制御の程度を提供します。
透明なプロキシパターン:このアプローチは、すべての外部呼び出しを実装契約にルーティングします。発信者が管理者であり、プロキシで管理機能に直接アクセスできます。これにより、ガバナンス操作が定期的なユーザーインタラクションを妨げないようにします。
UUPS(ユニバーサルアップグレード可能なプロキシ標準) :このモデルでは、アップグレードロジックは実装契約自体の一部です。これにより、実装レベルでアップグレードを制御できるようにすることにより、集中リスクが低下します。
ビーコンプロキシパターン:実装アドレスをハードコードする代わりに、ビーコンプロキシは、個別のビーコン契約から最新の実装アドレスを取得します。これにより、複数のプロキシを同時に大量にアップグレードできます。
これらの各モデルには、セキュリティ、分散化、メンテナンスの容易さの点でトレードオフがあり、プロジェクトの要件に応じて異なるユースケースに適しています。
基本的なプロキシ契約の実装:ステップバイステップガイド
基本的なプロキシ契約を作成するには、いくつかの正確な手順が含まれます。堅牢性を使用して手動で行う方法は次のとおりです。
実装契約の書き込み:標準的な堅牢性契約でアプリケーションのコアロジックを定義します。たとえば、バランス追跡および転送機能を備えた単純なトークン契約を作成します。
実装契約の展開:HardhatやTruffleなどの展開スクリプトまたはツールを使用して、実装契約を目的のネットワークに展開します。契約アドレスに注意してください。
プロキシ契約の作成:実装アドレスを保存し、
delegatecall
を使用して着信トランザクションを転送するプロキシ契約を作成します。フォールバックが不明な関数呼び出しを適切に処理することを確認してください。
pragma solidity ^0.8.0;
契約プロキシ{address public implementation; constructor(address _implementation) { implementation = _implementation; } fallback() external payable { address impl = implementation; assembly { let ptr := mload(0x40) calldatacopy(ptr, 0, calldatasize()) let result := delegatecall(gas(), impl, ptr, calldatasize(), 0, 0) let size := returndatasize() returndatacopy(ptr, 0, size) switch result case 0 { revert(ptr, size) } default { return(ptr, size) } } }
}
プロキシ契約の展開:プロキシを展開し、実装アドレスをコンストラクターに渡します。
プロキシと対話する:すべてのユーザーインタラクションはプロキシ契約を通過し、永続的な状態を維持しながら正しいロジックが実行されるようにする必要があります。
セキュリティ上の考慮事項とベストプラクティス
アップグレード性は、新しい攻撃ベクトルを導入し、慎重な取り扱いが必要です。ここにいくつかの重要な考慮事項があります:
管理者アクセス制御:信頼できるエンティティのみがアップグレードを開始できるはずです。不正な変更を防ぐために、マルチシグネチャウォレットまたはタイムロックを実装します。
ストレージ衝突:プロキシおよび実装契約にストレージ変数が重複している場合、データの破損が発生する可能性があります。競合を避けるために、Openzeppelinの
Initializable
なライブラリを使用します。テストと監査:ステージング環境でプロキシベースのシステムを徹底的にテストします。搾取可能な脆弱性がないことを確認するために、メインネットに展開する前に正式な監査を実施します。
ドキュメントと透明性:アップグレード手順を明確に文書化し、潜在的な変化についてユーザーと透明性を維持します。
ベストプラクティスを順守することにより、開発者はアップグレード可能なスマートコントラクトの利点を活用しながら、リスクを軽減できます。
よくある質問
Q1:プロキシ契約をアップグレードできますか?
いいえ、通常、アクセス制御メカニズムによって管理される管理特権を持つアドレスのみがアップグレードを実行できます。不正アクセスを防ぐには、適切な役割管理が不可欠です。
Q2:実装契約の過去のバージョンを追跡することは可能ですか?
はい、履歴実装アドレスをオンチェーンまたはオフチェーンで保存することにより、開発者は特定の期間に使用された以前のバージョンを監査および検証できます。
Q3:コール中に実装契約が元に戻すとどうなりますか?
実装契約が戻ると、トランザクションが失敗し、通話中に行われた状態の変更が展開されます。プロキシ契約は、失敗したロジックの変更を保持しません。
Q4:すべてのEthereum Virtual Machine(EVM)互換ブロックチェーンと互換性がありますか?
はい、 delegatecall
などの基本的なEVM機能に依存しているため、Binance Smart Chain、Polygon、AvalancheなどのすべてのEVM互換ネットワークでプロキシ契約が機能します。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- Bitcoin、Crypto&Bills:ニューヨーカーの支払いガイド!
- 2025-07-12 20:30:12
- XRP、Solana、およびAltcoinシーズンの話題:私たちはまだそこにいますか?
- 2025-07-12 20:30:12
- コードの割れ:2025年のブルランで暗号とアルトコインによる受動的収入
- 2025-07-12 18:30:12
- Crypto Bull Run:Troller Catのようなミームコインが料金をリードする
- 2025-07-12 18:30:12
- ソラナ、ミームコイン、イーサリアム:強気の暗号カクテル?
- 2025-07-12 18:50:12
- ChainLinkの登山:リンク価格、史上最高の高値、そして次のもの
- 2025-07-12 19:10:12
関連知識

Bitcoin契約は初心者に適していますか?
2025-07-12 20:14:42
Bitcoin契約の理解Bitcoin契約は、しばしばBitcoin先物または永続的な契約と呼ばれ、実際の資産を所有せずにBitcoinの価格についてトレーダーが推測できるようにする財務デリバティブです。これらの契約は、Bitcoinの基礎となる価格から価値を引き出し、Binance、Bybit、K...

孤立したマージンとクロスマージンとは何ですか?
2025-07-12 16:01:06
暗号通貨取引のマージンを理解する暗号通貨取引では、マージンとは、レバレッジされたポジションを開設して維持するために、トレーダーが預金しなければならない資金の量を指します。レバレッジされた取引により、トレーダーはブローカーや交換から資本を借りて潜在的なリターンを増やすことができますが、リスクも高まりま...

Bitcoin契約とは何ですか?
2025-07-12 18:21:40
Bitcoin契約とは何ですか? Bitcoin契約は、ブロックチェーンプラットフォーム上に構築され、Bitcoin(BTC)を基礎となる資産として利用するスマート契約またはデリバティブ契約を指します。これらの契約は、分散財務(DEFI)、取引、貸付などを含むさまざまな目的に役立ちます。従来の金融商...

短い先物のポジションのPNLを推定するにはどうすればよいですか?
2025-07-10 17:00:59
先物取引とPNLの基本を理解する先物取引では、トレーダーは、将来指定された時間に所定の価格で資産を売買する契約を締結します。あなたが短い先物のポジションをとるとき、あなたは本質的に基礎となる資産の価格が下落することを賭けています。あなたの利益と損失(PNL)は、市場があなたの初期エントリー価格に対し...

最も一般的なスマートコントラクトデザインパターンは何ですか?
2025-07-10 21:29:07
スマートコントラクトの設計パターンの紹介スマートコントラクトの設計パターンは、ブロックチェーンベースのアプリケーションの開発中に発生した繰り返しの問題に対する標準化されたソリューションです。これらのパターンは、開発者が安全で効率的で保守可能な方法でコードを構築するのに役立ちます。 Ethereumお...

スマート契約におけるコミットレビールスキームとは何ですか?
2025-07-10 17:22:03
コミットレビールスキームの概念を理解するブロックチェーンとスマートコントラクトの領域では、特に投票、オークション、または宝くじを含む分散型アプリケーション(DAPP)において、プライバシーと公平性が重大な懸念事項であることがよくあります。コミットリビールスキームは、参加者がすぐにそれを明らかにするこ...

Bitcoin契約は初心者に適していますか?
2025-07-12 20:14:42
Bitcoin契約の理解Bitcoin契約は、しばしばBitcoin先物または永続的な契約と呼ばれ、実際の資産を所有せずにBitcoinの価格についてトレーダーが推測できるようにする財務デリバティブです。これらの契約は、Bitcoinの基礎となる価格から価値を引き出し、Binance、Bybit、K...

孤立したマージンとクロスマージンとは何ですか?
2025-07-12 16:01:06
暗号通貨取引のマージンを理解する暗号通貨取引では、マージンとは、レバレッジされたポジションを開設して維持するために、トレーダーが預金しなければならない資金の量を指します。レバレッジされた取引により、トレーダーはブローカーや交換から資本を借りて潜在的なリターンを増やすことができますが、リスクも高まりま...

Bitcoin契約とは何ですか?
2025-07-12 18:21:40
Bitcoin契約とは何ですか? Bitcoin契約は、ブロックチェーンプラットフォーム上に構築され、Bitcoin(BTC)を基礎となる資産として利用するスマート契約またはデリバティブ契約を指します。これらの契約は、分散財務(DEFI)、取引、貸付などを含むさまざまな目的に役立ちます。従来の金融商...

短い先物のポジションのPNLを推定するにはどうすればよいですか?
2025-07-10 17:00:59
先物取引とPNLの基本を理解する先物取引では、トレーダーは、将来指定された時間に所定の価格で資産を売買する契約を締結します。あなたが短い先物のポジションをとるとき、あなたは本質的に基礎となる資産の価格が下落することを賭けています。あなたの利益と損失(PNL)は、市場があなたの初期エントリー価格に対し...

最も一般的なスマートコントラクトデザインパターンは何ですか?
2025-07-10 21:29:07
スマートコントラクトの設計パターンの紹介スマートコントラクトの設計パターンは、ブロックチェーンベースのアプリケーションの開発中に発生した繰り返しの問題に対する標準化されたソリューションです。これらのパターンは、開発者が安全で効率的で保守可能な方法でコードを構築するのに役立ちます。 Ethereumお...

スマート契約におけるコミットレビールスキームとは何ですか?
2025-07-10 17:22:03
コミットレビールスキームの概念を理解するブロックチェーンとスマートコントラクトの領域では、特に投票、オークション、または宝くじを含む分散型アプリケーション(DAPP)において、プライバシーと公平性が重大な懸念事項であることがよくあります。コミットリビールスキームは、参加者がすぐにそれを明らかにするこ...
すべての記事を見る
