市值: $2.1835T 0.48%
成交额(24h): $65.4124B -13.96%
恐惧与贪婪指数:

18 - 极度恐惧

  • 市值: $2.1835T 0.48%
  • 成交额(24h): $65.4124B -13.96%
  • 恐惧与贪婪指数:
  • 市值: $2.1835T 0.48%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

什么是代理合同?如何启用升级性?

Proxy contracts enable smart contract upgrades by separating logic from storage, using `delegatecall` to maintain state while updating functionality.

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),我们将及时删除。

相关百科

什么是资金费率翻转?为什么它经常预示着市场情绪的变化

什么是资金费率翻转?为什么它经常预示着市场情绪的变化

2026-06-14 03:57:05

市场波动模式1. Bitcoin 在重大宏观经济公告期间,24 小时内价格波动往往超过 10%。 2. 合并事件期间,以太坊的波动性指数飙升至 95 以上,反映出 Layer 1 和 Layer 2 生态系统的深度流动性碎片化。 3. 稳定币脱钩——例如 USDC 在 2023 年 3 月暂时偏离至...

如何识别加密货币期货市场中的市场操纵信号

如何识别加密货币期货市场中的市场操纵信号

2026-06-12 17:26:02

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

什么是杠杆陷阱?为什么零售贸易商经常被抓

什么是杠杆陷阱?为什么零售贸易商经常被抓

2026-06-12 23:53:36

市场波动模式1. Bitcoin 在 ETF 批准公告或重大交易所中断等高流动性事件期间,24 小时窗口内价格波动通常超过 5%。 2. 以太坊的波动性峰值与第 2 层采用指标密切相关,特别是当新的 Rollup 在主网上线并经历快速用户增长时。 3. 稳定币脱钩事件(例如 2023 年 3 月的 ...

什么是突破交易?期货交易者如何捕捉大幅价格变动

什么是突破交易?期货交易者如何捕捉大幅价格变动

2026-06-13 05:19:40

了解加密货币期货的突破机制1. 当 Bitcoin 或山寨币价格果断突破既定阻力位且交易量持续激增时,就会发生突破,通常会引发杠杆多头头寸的级联清算。 2. 在永续合约市场中,突破经常与融资利率飙升和未平仓合约扩张同时发生,这表明机构参与而不是散户噪音。 3. 与现货市场不同,加密货币期货的突破会被...

如何在重大经济公告期间交易加密货币期货

如何在重大经济公告期间交易加密货币期货

2026-06-12 22:50:44

市场波动模式1. Bitcoin 在减半公告或主要交易所上市等高流动性事件期间,单个 24 小时窗口内的价格波动通常超过 5%。 2. 过去 36 个月,山寨币与 BTC 的相关性平均高于 0.78,表明对 Bitcoin 方向性走势的强烈依赖。 3. 期货未平仓合约的飙升常常先于急剧逆转——尤其是...

什么是保证金余额?理解期货风险控制的核心

什么是保证金余额?理解期货风险控制的核心

2026-06-12 15:19:45

市场波动模式1. Bitcoin的价格波动通常与美国通胀报告和美联储利率决策等宏观经济指标相关。 2. 山寨币的走势经常反映 Bitcoin 的轨迹,尽管在反弹和调整期间幅度有所放大。 3. 交易所交易基金(ETF)批准公告立即引发现货和衍生品市场的流动性转移。 4. 从历史上看,鲸鱼钱包活动——尤...

什么是资金费率翻转?为什么它经常预示着市场情绪的变化

什么是资金费率翻转?为什么它经常预示着市场情绪的变化

2026-06-14 03:57:05

市场波动模式1. Bitcoin 在重大宏观经济公告期间,24 小时内价格波动往往超过 10%。 2. 合并事件期间,以太坊的波动性指数飙升至 95 以上,反映出 Layer 1 和 Layer 2 生态系统的深度流动性碎片化。 3. 稳定币脱钩——例如 USDC 在 2023 年 3 月暂时偏离至...

如何识别加密货币期货市场中的市场操纵信号

如何识别加密货币期货市场中的市场操纵信号

2026-06-12 17:26:02

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

什么是杠杆陷阱?为什么零售贸易商经常被抓

什么是杠杆陷阱?为什么零售贸易商经常被抓

2026-06-12 23:53:36

市场波动模式1. Bitcoin 在 ETF 批准公告或重大交易所中断等高流动性事件期间,24 小时窗口内价格波动通常超过 5%。 2. 以太坊的波动性峰值与第 2 层采用指标密切相关,特别是当新的 Rollup 在主网上线并经历快速用户增长时。 3. 稳定币脱钩事件(例如 2023 年 3 月的 ...

什么是突破交易?期货交易者如何捕捉大幅价格变动

什么是突破交易?期货交易者如何捕捉大幅价格变动

2026-06-13 05:19:40

了解加密货币期货的突破机制1. 当 Bitcoin 或山寨币价格果断突破既定阻力位且交易量持续激增时,就会发生突破,通常会引发杠杆多头头寸的级联清算。 2. 在永续合约市场中,突破经常与融资利率飙升和未平仓合约扩张同时发生,这表明机构参与而不是散户噪音。 3. 与现货市场不同,加密货币期货的突破会被...

如何在重大经济公告期间交易加密货币期货

如何在重大经济公告期间交易加密货币期货

2026-06-12 22:50:44

市场波动模式1. Bitcoin 在减半公告或主要交易所上市等高流动性事件期间,单个 24 小时窗口内的价格波动通常超过 5%。 2. 过去 36 个月,山寨币与 BTC 的相关性平均高于 0.78,表明对 Bitcoin 方向性走势的强烈依赖。 3. 期货未平仓合约的飙升常常先于急剧逆转——尤其是...

什么是保证金余额?理解期货风险控制的核心

什么是保证金余额?理解期货风险控制的核心

2026-06-12 15:19:45

市场波动模式1. Bitcoin的价格波动通常与美国通胀报告和美联储利率决策等宏观经济指标相关。 2. 山寨币的走势经常反映 Bitcoin 的轨迹,尽管在反弹和调整期间幅度有所放大。 3. 交易所交易基金(ETF)批准公告立即引发现货和衍生品市场的流动性转移。 4. 从历史上看,鲸鱼钱包活动——尤...

查看所有文章

User not found or password invalid

Your input is correct