市值: $3.2432T 0.86%
成交额(24h): $102.3967B -56.12%
恐惧与贪婪指数:

16 - 极度恐惧

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

选择语种

选择语种

选择货币

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

什么是整数溢出和下溢漏洞以及 SafeMath 如何预防它们?

Integer overflow and underflow in smart contracts can lead to critical vulnerabilities, enabling attackers to manipulate balances and disrupt decentralized economies.

2025/11/14 09:59

了解智能合约中的整数溢出和下溢

1. 在区块链开发中,特别是在用 Solidity 编写的以太坊智能合约中,算术运算直接对无符号整数执行。当计算超过数据类型可以容纳的最大值时,就会发生整数溢出。例如,如果 uint8 变量保存 255 并且加 1,它会回绕到 0,而不是变成 256。

2. 相反,当减法运算的结果低于最小可表示值时,就会发生整数下溢。如果 uint8 变量包含 0 并减 1,它将回绕到 255。这些行为源于以太坊虚拟机 (EVM) 中低级算术的工作方式,该虚拟机不会自动检查此类边界违规。

3.此类漏洞可能被恶意利用。攻击者可能会操纵代币余额、夸大所有权或触发意外的逻辑流。 BeautyChain 代币发生了一个著名的案例,溢出使攻击者能够生成大量代币,从而破坏经济稳定。

4. 这些缺陷通常潜伏在代码中,直到被特定输入触发。由于它们在正常 EVM 执行下不会产生运行时错误,因此它们在基本测试期间保持不可见。它们的存在破坏了去中心化应用程序中金融运营的完整性。

5. 影响不仅限于个人合同。基于溢出或下溢的漏洞可能会削弱用户信任,导致资金损失,并损害基于受影响协议构建的整个平台的声誉。

SafeMath 库在降低风险方面的作用

1. 为了解决这些风险,引入了 SafeMath 库作为防御性编程工具。它提供了加法、减法、乘法和除法的包装函数,其中包括在执行任何操作之前的显式检查。

2. 使用 SafeMath.add(a, b) 时,该函数首先验证总和不会超过给定类型的最大值。如果结果溢出,事务将通过 require 语句恢复,从而阻止执行。

3. 同样,SafeMath.sub(a, b) 在减法之前确保 a 大于或等于 b。如果不是,操作将恢复,从而阻止可能破坏余额跟踪或访问控制机制的潜在下溢情况。

4. SafeMath.mul(a, b) 检查大数相乘时出现的溢出情况。即使两个操作数单独看起来都是安全的,它们的乘积也可能会超出存储限制,特别是在基于乘法器铸造代币等扩展操作中。

5. 通过恢复条件强制算术安全,SafeMath 有效地消除了整个类别的漏洞利用。在几次引人注目的黑客攻击强调了金融逻辑中输入验证的必要性之后,它的采用变得广泛。

算术保障措施的整合与演变

1. 开发人员通过导入库并使用“using”指令将其附加到 uint 类型来集成 SafeMath。应用后,标准操作员将在整个合同范围内自动替换为已检查的对应操作员。

2. 虽然 SafeMath 增加的 Gas 开销最小,但其安全效益远远超过成本。每次检查都会消耗额外的计算量,但这种投资可以防止可能导致不可逆转的资产损失的灾难性故障。

3. 现代版本的 Solidity(从 0.8.0 开始)已将上溢和下溢检查原生集成到语言中。这意味着算术运算现在默认恢复,无需外部库,从而减少了对较新代码库中 SafeMath 的依赖。

4. 尽管有本机支持,但由于向后兼容性要求,许多遗留系统仍然依赖 SafeMath。作为漏洞评估的一部分,审计员会定期检查旧合同是否缺少 SafeMath 的使用。

5. 向更安全的违约的过渡反映了更广泛的行业学习。曾经需要手动干预的内容现在已嵌入到编译器行为中,说明了现实世界中的漏洞如何推动语言设计和开发人员工具的改进。

正确使用算术保护措施可以防止对余额和津贴等关键值进行未经授权的操纵,从而保护去中心化应用程序的经济模型。

常见问题解答

当 SafeMath 检查失败时会发生什么?当 SafeMath 操作检测到不安全的算术条件时,它会触发恢复。这将取消事务并将状态恢复到执行开始之前的状态,确保不会永久记录任何更改。

有符号整数也会发生溢出吗?是的,有符号整数也容易受到攻击。根据操作,它们可以溢出到负范围或下溢到正范围。尽管在余额跟踪中不太常见,但它们在控制逻辑和索引方面带来了类似的风险。

Solidity 0.8+ 中还需要 SafeMath 吗?在大多数情况下,不会。 Solidity 0.8 及更高版本包含针对所有算术运算的内置溢出和下溢保护。但是,为了明确清晰度或在使用未经检查的块时,开发人员仍然可以使用 SafeMath。

SafeMath 是否存在性能成本?每个 SafeMath 函数都包含条件检查,与原始算术相比,这些条件检查会消耗额外的 Gas。虽然每次操作的增量很小,但它可能会在涉及循环或频繁更新的复杂计算中累积。

免责声明:info@kdj.com

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

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

相关百科

什么是智能合约中的拒绝服务 (DoS) 攻击?其常见形式有哪些?

什么是智能合约中的拒绝服务 (DoS) 攻击?其常见形式有哪些?

2025-11-10 05:20:08

了解智能合约中的拒绝服务1. 智能合约中的拒绝服务(DoS)攻击是指恶意行为者阻止合法用户访问或使用合约功能的情况。这通常是通过利用允许攻击者阻止关键操作的设计缺陷来实现的。与针对 Web 服务器的传统 DoS 攻击不同,基于区块链的 DoS 攻击利用了智能合约的不可变和透明特性。 2. 这些攻击的...

交易签名中使用的加密随机数是什么?

交易签名中使用的加密随机数是什么?

2025-11-11 05:59:39

了解区块链交易中的加密随机数1. 加密随机数是在区块链网络中的交易签名上下文中仅使用一次的随机数或伪随机数。其主要功能是确保每笔交易都是唯一的并且不会被恶意行为者重播。如果没有随机数,相同的交易可能会被多次提交,从而导致意外的转账或余额差异。 2. 在以太坊等系统中,随机数直接与发送者的帐户绑定,并...

Solidity 智能合约中的继承是如何工作的?

Solidity 智能合约中的继承是如何工作的?

2025-11-11 22:40:12

Solidity 的继承:构建模块化智能合约1. Solidity 中的继承允许一个合约采用另一个合约的属性和功能,从而实现代码重用和结构化设计。派生合约可以从基础合约继承,获得对其状态变量、函数和修饰符的访问权限,前提是它们没有标记为私有。该机制支持逻辑的分层组织,减少多个合约之间的冗余。 2. ...

外部拥有账户 (EOA) 和合约账户有什么区别?

外部拥有账户 (EOA) 和合约账户有什么区别?

2025-11-13 04:00:32

了解外部拥有账户 (EOA) 1. 外部拥有的账户由私钥直接控制,这意味着只有该密钥的持有者才能从该账户发起交易。 EOA 没有任何关联代码;它们是用于在区块链上发送和接收交易的简单地址。这些帐户通常是在用户使用 MetaMask 或 Ledger 等工具生成钱包时创建的,从而产生公共地址和相应的私...

什么是 ERC-2981 NFT 版税标准以及它如何运作?

什么是 ERC-2981 NFT 版税标准以及它如何运作?

2025-11-13 05:39:54

了解 ERC-2981 NFT 版税标准1. ERC-2981 标准是一项拟议的以太坊征求意见稿,它引入了非同质代币 (NFT) 的版税机制。与 ERC-721 和 ERC-1155 等早期 NFT 标准缺乏对版税的内置支持不同,ERC-2981 使创作者每次 NFT 在二级市场转售时都能获得补偿。...

什么是 DeFi 中的三明治攻击以及它如何利用交易?

什么是 DeFi 中的三明治攻击以及它如何利用交易?

2025-11-15 18:39:40

了解去中心化金融中的三明治攻击1. 三明治攻击是一种在依赖自动做市商 (AMM) 的去中心化交易所 (DEX) 中常见的前置运行和后台运行操纵形式。当恶意行为者在受害者的交易之前进行两笔交易,一笔在受害者的交易之后进行交易时,就会发生这些攻击,以从目标交易造成的价格影响中获利。攻击者有效地将受害者的...

什么是智能合约中的拒绝服务 (DoS) 攻击?其常见形式有哪些?

什么是智能合约中的拒绝服务 (DoS) 攻击?其常见形式有哪些?

2025-11-10 05:20:08

了解智能合约中的拒绝服务1. 智能合约中的拒绝服务(DoS)攻击是指恶意行为者阻止合法用户访问或使用合约功能的情况。这通常是通过利用允许攻击者阻止关键操作的设计缺陷来实现的。与针对 Web 服务器的传统 DoS 攻击不同,基于区块链的 DoS 攻击利用了智能合约的不可变和透明特性。 2. 这些攻击的...

交易签名中使用的加密随机数是什么?

交易签名中使用的加密随机数是什么?

2025-11-11 05:59:39

了解区块链交易中的加密随机数1. 加密随机数是在区块链网络中的交易签名上下文中仅使用一次的随机数或伪随机数。其主要功能是确保每笔交易都是唯一的并且不会被恶意行为者重播。如果没有随机数,相同的交易可能会被多次提交,从而导致意外的转账或余额差异。 2. 在以太坊等系统中,随机数直接与发送者的帐户绑定,并...

Solidity 智能合约中的继承是如何工作的?

Solidity 智能合约中的继承是如何工作的?

2025-11-11 22:40:12

Solidity 的继承:构建模块化智能合约1. Solidity 中的继承允许一个合约采用另一个合约的属性和功能,从而实现代码重用和结构化设计。派生合约可以从基础合约继承,获得对其状态变量、函数和修饰符的访问权限,前提是它们没有标记为私有。该机制支持逻辑的分层组织,减少多个合约之间的冗余。 2. ...

外部拥有账户 (EOA) 和合约账户有什么区别?

外部拥有账户 (EOA) 和合约账户有什么区别?

2025-11-13 04:00:32

了解外部拥有账户 (EOA) 1. 外部拥有的账户由私钥直接控制,这意味着只有该密钥的持有者才能从该账户发起交易。 EOA 没有任何关联代码;它们是用于在区块链上发送和接收交易的简单地址。这些帐户通常是在用户使用 MetaMask 或 Ledger 等工具生成钱包时创建的,从而产生公共地址和相应的私...

什么是 ERC-2981 NFT 版税标准以及它如何运作?

什么是 ERC-2981 NFT 版税标准以及它如何运作?

2025-11-13 05:39:54

了解 ERC-2981 NFT 版税标准1. ERC-2981 标准是一项拟议的以太坊征求意见稿,它引入了非同质代币 (NFT) 的版税机制。与 ERC-721 和 ERC-1155 等早期 NFT 标准缺乏对版税的内置支持不同,ERC-2981 使创作者每次 NFT 在二级市场转售时都能获得补偿。...

什么是 DeFi 中的三明治攻击以及它如何利用交易?

什么是 DeFi 中的三明治攻击以及它如何利用交易?

2025-11-15 18:39:40

了解去中心化金融中的三明治攻击1. 三明治攻击是一种在依赖自动做市商 (AMM) 的去中心化交易所 (DEX) 中常见的前置运行和后台运行操纵形式。当恶意行为者在受害者的交易之前进行两笔交易,一笔在受害者的交易之后进行交易时,就会发生这些攻击,以从目标交易造成的价格影响中获利。攻击者有效地将受害者的...

查看所有文章

User not found or password invalid

Your input is correct