-
Bitcoin
$117,684.2943
-0.23% -
Ethereum
$2,953.9656
-1.85% -
XRP
$2.7890
7.84% -
Tether USDt
$1.0004
0.02% -
BNB
$691.4391
-0.44% -
Solana
$162.9971
-1.73% -
USDC
$1.0000
0.03% -
Dogecoin
$0.2021
1.22% -
TRON
$0.3035
2.65% -
Cardano
$0.7201
3.30% -
Hyperliquid
$46.2475
2.16% -
Stellar
$0.3837
24.94% -
Sui
$3.4018
-3.52% -
Chainlink
$15.2192
-1.96% -
Bitcoin Cash
$517.2887
-1.40% -
Avalanche
$20.7170
-1.87% -
UNUS SED LEO
$9.0804
0.73% -
Hedera
$0.1967
-1.34% -
Shiba Inu
$0.0...01325
-2.62% -
Toncoin
$2.9835
-0.35% -
Litecoin
$93.2415
-3.13% -
Polkadot
$3.9478
-0.88% -
Monero
$331.6841
0.75% -
Uniswap
$8.5415
-3.44% -
Dai
$1.0000
0.00% -
Ethena USDe
$1.0008
0.01% -
Pepe
$0.0...01230
-5.06% -
Bitget Token
$4.3965
-4.53% -
Aave
$298.9297
-4.28% -
Bittensor
$392.4513
1.77%
什么是代理合同?如何启用升级性?
代理合同通过将逻辑与存储分开,使用`delegateCall`在更新功能时都保持状态来启用智能合约升级。
2025/07/10 19:42

了解智能合同开发中的代理合同
在区块链和智能合同开发的世界中,代理合同已成为一种至关重要的设计模式。与一旦部署的传统智能合约不同,代理合同提供了一种结构化的机制来实施变更和升级,而无需重新部署整个合同。在以太坊等环境中,这种灵活性尤为重要,在以太坊等环境中,部署代码无法直接更改。代理合同是用户与应用程序的实际逻辑之间的中介,使开发人员可以随着时间的推移更新功能。
代理合同的工作方式:技术概述
从本质上讲,代理合同围绕另一个称为“实施合同”的合同充当外墙或包装。当用户与代理进行交互时,它将使用delegatecall
opcode将功能调用到实现合同。此操作码可确保执行上下文(例如存储和发件人地址)与代理的状态保持一致,即使逻辑驻留在其他地方。
- 代理保持合同的状态。
- 实施合同包含业务逻辑。
- 通过代理到当前实现,用户的函数调用被路由。
这种分离允许更新实现,同时保留了与代理地址相关的所有现有数据和交互。
VelegateCall在启用升级性中的作用
可以在代理合同中升级的关键技术功能是delegatecall
机制。在坚固性方面, delegatecall
允许一份合同从另一个合同中执行代码,同时维护呼叫者的存储,价值和上下文。这意味着,当代理合同使用delegatecall
在实施合同上调用功能时,执行过程中所做的任何更改都会影响代理的存储,而不是实施。
这种行为至关重要,因为:
- 它可以确保即使升级后,数据仍然存在。
- 它将逻辑与存储的逻辑分开,这对于将来的修改是必需的。
如果没有delegatecall
,升级将需要重新部署合同及其相关数据,从而导致潜在的不一致和信息丢失。
实践中使用的代理模式的类型
以太坊生态系统中存在几种代理模式,每种模式都提供不同程度的复杂性和控制性:
透明代理模式:此方法将所有外部呼叫路由到实施合同,除非呼叫者是管理员,否则可以直接在代理上访问管理职能。这样可以确保治理操作不会干扰常规的用户互动。
UUPS(通用升级代理标准) :在此模型中,升级逻辑是实施合同本身的一部分。这通过允许在实施级别控制升级来降低集中化风险。
Beacon代理模式:Beacon Proxy不是对实现地址进行硬编码,而是从单独的信标合同中检索了最新的实施地址。这可以同时跨多个代理进行大规模升级。
这些模型中的每一个都在安全性,权力下放和易于维护方面都有权衡,因此根据项目要求,它们适用于不同的用例。
实施基本代理合同:逐步指南
创建基本代理合同涉及几个精确的步骤。这是使用坚固性手动进行操作的方法:
编写实施合同:在标准固定合同中定义应用程序的核心逻辑。例如,使用余额跟踪和传输功能创建一个简单的令牌合同。
部署实施合同:使用部署脚本或诸如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
的库,以避免冲突。测试和审核:在分期环境中彻底测试基于代理的系统。在部署到主网之前进行正式审核,以确保没有可利用的漏洞。
文档和透明度:清楚地记录升级过程,并与用户保持潜在变化的透明度。
通过遵守最佳实践,开发人员可以减轻风险,同时利用可升级的智能合约的好处。
常见问题
问题1:任何人都可以升级代理合同吗?
不,只有具有行政特权的地址,通常由访问控制机制支配,才能执行升级。适当的角色管理对于防止未经授权的访问至关重要。
问题2:是否可以跟踪实施合同的过去版本?
是的,通过存储历史实施解决链或链链的地址,开发人员可以审核并验证特定时期内使用的先前版本。
问题3:如果实施合同在通话期间恢复会发生什么?
如果实施合同恢复了,则交易将失败,并且在呼叫期间进行的任何状态更改都将被回滚。代理合同没有保留失败的逻辑更改。
问题4:代理合同是否与所有以太坊虚拟机(EVM)兼容的区块链兼容?
是的,由于它们依靠诸如delegatecall
类的基本EVM功能,因此代理合同在所有兼容EVM兼容网络(例如Binance Smart Chain,Polygon和Avalanche)中起作用。
免责声明:info@kdj.com
所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!
如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。
- 埃迪(Eddie)摇滚皇家造币厂:铁娘的50周年获得硬币化!
- 2025-07-12 16:30:11
- SUI价格飙升,出现了:2025年的Defi和Altcoin机会
- 2025-07-12 17:10:12
- XLM Price在出色的升级嗡嗡声中飙升:$ 1可触及?
- 2025-07-12 17:10:12
- Pumpfun,Solana和Launchpad比赛:模因硬币竞技场?
- 2025-07-12 16:50:12
- Pepe硬币价格预测:泵还是转储?青蛙模因的下一步是什么?
- 2025-07-12 16:30:11
- Binance,CZ和Trump Family:加密探戈?
- 2025-07-12 17:15:12
相关百科

什么是孤立的边缘与交叉边缘?
2025-07-12 16:01:06
了解加密货币交易的利润率在加密货币交易中,保证金是指交易员必须存入以打开和维持杠杆头寸的资金数量。杠杆交易允许交易者从经纪人或交易所借资本以增加其潜在收益,尽管这也增加了风险。大多数加密衍生品平台上使用了两种主要的边缘模式:隔离边缘和交叉边缘。每个人都有自己的一系列优势和缺点,具体取决于交易者的战略...

如何估计短期期货职位的PNL?
2025-07-10 17:00:59
了解期货交易和PNL的基础知识在期货交易中,交易员签订了一份合同,以预定的价格在未来的指定时间以预定的价格购买或出售资产。当您担任短期期货职位时,您实际上是在押注基础资产的价格将下降。您的利润和损失(PNL)取决于市场与您初始入境价格相对的程度。估计PNL的第一步是了解您要交易的期货工具的合同规格。...

最常见的智能合同设计模式是什么?
2025-07-10 21:29:07
智能合同设计模式简介智能合约设计模式是标准化解决方案,用于在基于区块链的应用程序开发过程中遇到的重复问题。这些模式有助于开发人员以安全,高效且可维护的方式构建其代码。在以太坊和其他与EVM兼容的区块链的背景下,了解这些模式对于构建强大的分散应用程序(DAPP)至关重要。本文探讨了加密货币领域中使用的...

智能合同中的提交计划是什么?
2025-07-10 17:22:03
了解委员会计划的概念在区块链和智能合约领域,隐私和公平通常是关键问题,尤其是在涉及投票,拍卖或彩票的分散申请(DAPP)中。违反计划的计划是一种加密机制,旨在通过使参与者能够在不立即透露价值的情况下解决这些问题,然后在适当时披露(揭示)。该计划确保没有参与者在看到他人的投入后可以改变自己的选择,从而...

产量养殖聚合商如何使用智能合约?
2025-07-11 02:49:40
了解智能合约在产量耕种汇总者中的作用产量养殖聚合商利用智能合约来自动化和优化多个分散融资(DEFI)协议的产量产生过程。这些智能合约是与直接写入代码的术语的自我执行协议,该协议部署在以太坊或binance智能链等区块链网络上。智能合约的使用使聚合器能够无缝与各种Fefi平台进行交互,而无需用户手动输...

Cardano的智能合同如何工作?
2025-07-12 10:56:25
了解Cardano的智能合约智能合约是与直接写入代码的条款的自我执行协议。在第三代区块链平台Cardano上,智能合约与以太坊相比,由于其独特的架构以及可扩展性和安全性的方法。 Cardano的智能合约的实现是基于分层结构,该结构将帐户值分类账与智能合约所在的计算层分开。计算层被称为Cardano ...

什么是孤立的边缘与交叉边缘?
2025-07-12 16:01:06
了解加密货币交易的利润率在加密货币交易中,保证金是指交易员必须存入以打开和维持杠杆头寸的资金数量。杠杆交易允许交易者从经纪人或交易所借资本以增加其潜在收益,尽管这也增加了风险。大多数加密衍生品平台上使用了两种主要的边缘模式:隔离边缘和交叉边缘。每个人都有自己的一系列优势和缺点,具体取决于交易者的战略...

如何估计短期期货职位的PNL?
2025-07-10 17:00:59
了解期货交易和PNL的基础知识在期货交易中,交易员签订了一份合同,以预定的价格在未来的指定时间以预定的价格购买或出售资产。当您担任短期期货职位时,您实际上是在押注基础资产的价格将下降。您的利润和损失(PNL)取决于市场与您初始入境价格相对的程度。估计PNL的第一步是了解您要交易的期货工具的合同规格。...

最常见的智能合同设计模式是什么?
2025-07-10 21:29:07
智能合同设计模式简介智能合约设计模式是标准化解决方案,用于在基于区块链的应用程序开发过程中遇到的重复问题。这些模式有助于开发人员以安全,高效且可维护的方式构建其代码。在以太坊和其他与EVM兼容的区块链的背景下,了解这些模式对于构建强大的分散应用程序(DAPP)至关重要。本文探讨了加密货币领域中使用的...

智能合同中的提交计划是什么?
2025-07-10 17:22:03
了解委员会计划的概念在区块链和智能合约领域,隐私和公平通常是关键问题,尤其是在涉及投票,拍卖或彩票的分散申请(DAPP)中。违反计划的计划是一种加密机制,旨在通过使参与者能够在不立即透露价值的情况下解决这些问题,然后在适当时披露(揭示)。该计划确保没有参与者在看到他人的投入后可以改变自己的选择,从而...

产量养殖聚合商如何使用智能合约?
2025-07-11 02:49:40
了解智能合约在产量耕种汇总者中的作用产量养殖聚合商利用智能合约来自动化和优化多个分散融资(DEFI)协议的产量产生过程。这些智能合约是与直接写入代码的术语的自我执行协议,该协议部署在以太坊或binance智能链等区块链网络上。智能合约的使用使聚合器能够无缝与各种Fefi平台进行交互,而无需用户手动输...

Cardano的智能合同如何工作?
2025-07-12 10:56:25
了解Cardano的智能合约智能合约是与直接写入代码的条款的自我执行协议。在第三代区块链平台Cardano上,智能合约与以太坊相比,由于其独特的架构以及可扩展性和安全性的方法。 Cardano的智能合约的实现是基于分层结构,该结构将帐户值分类账与智能合约所在的计算层分开。计算层被称为Cardano ...
查看所有文章
