市值: $2.1591T 2.61%
成交额(24h): $74.6886B -50.71%
恐惧与贪婪指数:

15 - 极度恐惧

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

选择语种

选择语种

选择货币

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

什么是检查-效果-交互模式以及为什么它是安全最佳实践?

The Check-Effects-Interactions pattern prevents reentrancy attacks by ensuring state changes occur before external calls, enhancing smart contract security.

2025/11/18 01:39

了解检查-效果-交互模式

1. 检查-效果-交互 (CEI) 模式是智能合约开发中广泛采用的设计原则,特别是在以太坊和其他与 EVM 兼容的区块链中。它将函数执行分为三个不同的阶段,以最大限度地减少重入攻击引起的漏洞。这种方法确保在进行任何外部调用之前发生状态更改,从而降低恶意合约利用回调机制的风险。

2. 在“检查”阶段,合约验证所有先决条件,例如访问控制、输入参数和所需余额。这些验证确保交易在进一步处理之前满足所有必要的标准。跳过或乱序此步骤可能会让攻击者在无效条件下触发功能。

3.“效果”阶段涉及更新合约的内部状态变量。这包括修改余额、所有权标志或状态指示器。通过在进行外部调用之前完成这些更新,合约可以防止攻击者在执行过程中重复输入相同的函数来操纵数据。

4.“交互”阶段是合约调用其他合约上的外部函数或发送以太币的阶段。因为这种情况发生在所有检查和状态更新之后,即使被调用的合约尝试重新进入原始函数,它也会遇到更新的状态值,从而防止意外行为。

5. 正确实施 CEI 需要严格的编码实践。开发人员必须抵制外部调用与内部逻辑交错的诱惑,尤其是在处理用户提供的地址时。偏离此顺序可能会重新引入该模式旨在消除的风险。

可重入背景下的安全影响

1. 重入攻击利用了这样一个事实:外部调用可以在调用合约的状态完全更新之前触发回调。 2016 年臭名昭著的 DAO 黑客事件表明,此类缺陷可能会导致灾难性的资金损失。通过遵守 CEI,开发人员可以在架构级别关闭此攻击媒介。

2. 当合约转移资金或触发另一个合约的功能时,接收者可以执行任意代码,包括回调原始合约。如果状态更改尚未提交,则可重入调用会看到过时的数据,并且可能会错误地通过验证检查。

3. CEI提供的核心防御在于确保在所有相关状态修改完成之前不会发生外部交互。这保证了任何后续的可重入调用在新状态下运行,通常会阻止进一步的撤回或操作。

4. Solidity 的编译器警告和静态分析器等现代工具有助于检测与 CEI 的偏差。然而,仅依靠自动化是不够的。手动审查和遵守安全设计模式仍然是稳健合同开发的重要组成部分。

5. 即使实施了 CEI,某些边缘情况也需要额外的保护措施。例如,使用拉推支付模型或实施重入防护可以提供分层保护,尤其是在涉及多个交互合约的复杂系统中。

实施示例和常见陷阱

1. 典型的有缺陷的实现可能仅在发送以太币后才从用户的余额中扣除,从而创建了重新输入的窗口。正确使用先扣除余额,然后再进行转账。这种简单的重新排序可以消除威胁。

2. OpenZeppelin 等库提供了可重复使用的组件来执行 CEI 原则。它们的退出模式通常包括不可重入修饰符,这些修饰符充当预期执行流的运行时强制执行。

3.一个常见的错误是将 CEI 视为看似“安全”的外部调用的可选选项,例如记录事件或查询数据。虽然只读操作带来的风险较小,但将它们与状态更改逻辑混合可能会掩盖实际的执行顺序并导致疏忽。

4. 集成行为不完全可信的第三方合约时会出现另一个陷阱。即使您的合约遵循 CEI,外部代码中的意外行为(例如意外回调或天然气补贴)如果没有正确考虑,仍然可能会引入漏洞。

5. 测试在验证是否符合 CEI 方面发挥着至关重要的作用。单元测试应模拟重入场景,以确认状态更改可防止重复利用。模糊测试和符号执行工具还可以发现手动检查可能遗漏的细微违规行为。

常见问题解答

如果函数跳过效果阶段会发生什么?在外部调用之前跳过内部状态更新会使合约面临重入的风险。攻击者可以在原始调用仍处于待处理状态时重复调用该函数,在系统识别初始交易的影响之前耗尽资金或操纵数据。

检查-效果-交互模式可以应用于视图或纯函数吗?视图和纯函数不会修改状态或执行外部调用,因此 CEI 不适用。这些函数本质上是安全的,不会重入,但仍必须仔细设计,以避免通过侧通道泄漏敏感信息。

CEI 足以保护所有类型的智能合约交互吗?虽然 CEI 有效地缓解了重入问题,但它并没有解决其他严重漏洞,例如整数溢出、不正确的访问控制或抢先交易。安全性需要一种整体方法,结合多种最佳实践,而不仅仅是执行顺序。

免责声明:info@kdj.com

所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!

如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。

相关百科

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

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

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

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

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

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

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

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

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

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

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

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

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

查看所有文章

User not found or password invalid

Your input is correct