智能合约安全漏洞解析:从 Reentrancy 到 Integer Overflow

news2025/6/6 16:50:38

目录

🌀 Reentrancy(重入攻击)

原理解析

典型案例:The DAO 攻击事件

漏洞示例

防范措施

🔢 Integer Overflow(整数溢出)

原理解析

漏洞示例

防范措施

🛡️ 总结与建议


随着区块链技术的广泛应用,智能合约在去中心化金融(DeFi)、NFT、DAO 等领域扮演着越来越重要的角色。然而,智能合约的安全性问题也日益凸显,尤其是 Reentrancy(重入攻击)和 Integer Overflow(整数溢出)等经典漏洞,曾导致多起严重的安全事件。本文将深入解析这两类漏洞的原理、典型案例,并提供防范建议,帮助开发者构建更安全的智能合约。


🌀 Reentrancy(重入攻击)

原理解析

Reentrancy 是指攻击者在智能合约执行过程中,通过外部调用再次进入原函数,导致合约状态未及时更新,从而实现多次调用、重复操作的攻击方式。

攻击流程通常如下:

  1. 攻击者向目标合约存入一定的资金。

  2. 调用目标合约的提现函数,该函数在转账前未更新用户余额。

  3. 攻击者在接收到转账时,利用 fallback 或 receive 函数再次调用提现函数。

  4. 由于余额尚未更新,攻击者可以重复提现,直到合约资金耗尽。

典型案例:The DAO 攻击事件

2016 年,The DAO 项目遭受 Reentrancy 攻击,攻击者利用合约中的漏洞,反复调用提现函数,最终盗取了约 360 万个 ETH,导致以太坊社区进行了一次硬分叉,以恢复被盗资金 。

漏洞示例

pragma solidity ^0.8.0;

contract Vulnerable {
    mapping(address => uint) public balances;

    function deposit() public payable {
        balances[msg.sender] += msg.value;
    }

    function withdraw(uint _amount) public {
        require(balances[msg.sender] >= _amount, "Insufficient balance");
        (bool success, ) = msg.sender.call{value: _amount}("");
        require(success, "Transfer failed");
        balances[msg.sender] -= _amount;
    }
}

上述合约在转账后才更新用户余额,攻击者可以在接收到转账时,利用 fallback 函数再次调用 withdraw,实现重复提现。

防范措施

  1. 遵循 Checks-Effects-Interactions 模式:先进行状态检查和更新,再进行外部调用。

function withdraw(uint _amount) public {
    require(balances[msg.sender] >= _amount, "Insufficient balance");
    balances[msg.sender] -= _amount;
    (bool success, ) = msg.sender.call{value: _amount}("");
    require(success, "Transfer failed");
}
  1. 使用 ReentrancyGuard:引入互斥锁,防止重入。

import "@openzeppelin/contracts/security/ReentrancyGuard.sol";

contract Secure is ReentrancyGuard {
    function withdraw(uint _amount) public nonReentrant {
        // 安全的提现逻辑
    }
}
  1. 限制外部调用:避免在合约中进行不必要的外部调用,降低攻击面。


🔢 Integer Overflow(整数溢出)

原理解析

整数溢出是指在进行算术运算时,结果超出了数据类型的表示范围,导致数值回绕。例如,uint8 的最大值为 255,若执行 255 + 1,结果将变为 0。

在 Solidity 0.8 之前,整数溢出不会抛出异常,攻击者可以利用这一特性,绕过合约中的安全检查。

漏洞示例

pragma solidity ^0.7.0;

contract Overflow {
    uint8 public count = 255;

    function increment() public {
        count += 1; // count 将变为 0
    }
}

在上述合约中,count 的初始值为 255,调用 increment 后,count 将变为 0,可能导致逻辑错误或安全漏洞。

防范措施

  1. 升级 Solidity 版本:Solidity 0.8 及以上版本默认启用了溢出检查,溢出将导致交易失败。

  2. 使用 SafeMath 库:在旧版本中,可引入 SafeMath 库,进行安全的算术运算。

pragma solidity ^0.7.0;
import "@openzeppelin/contracts/math/SafeMath.sol";

contract Safe {
    using SafeMath for uint8;
    uint8 public count = 255;

    function increment() public {
        count = count.add(1); // 若溢出,将抛出异常
    }
}
  1. 避免类型转换错误:在进行类型转换时,确保不会引入溢出风险。例如,将较大的整数转换为较小的数据类型时,要进行范围检查。


🛡️ 总结与建议

智能合约的安全性至关重要,Reentrancy 和 Integer Overflow 是两类常见且危害严重的漏洞。开发者在编写合约时,应:

  • 遵循最佳实践,如 Checks-Effects-Interactions 模式。

  • 使用最新版本的 Solidity,利用其内置的安全特性。

  • 引入成熟的安全库,如 OpenZeppelin 提供的 ReentrancyGuard 和 SafeMath。

  • 进行充分的测试和审计,及时发现并修复潜在漏洞。

通过以上措施,可以有效提升智能合约的安全性,保障区块链应用的稳定运行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2399311.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

英国2025年战略防御评估报告:网络与电磁域成现代战争核心

英国 2025 年战略防御评估 (SDR) 详细制定了一项计划,通过加强使用网络、人工智能和数字战争来整合其军事防御和进攻能力。 与美国一样,英国也被认为(尽管未被公开证实)会开展进攻性网络行动,甚至针对盟友。斯诺登泄露…

基于QPSK调制解调+Polar编译码(SCL译码)的matlab性能仿真,并对比BPSK

目录 1.引言 2.算法仿真效果演示 3.数据集格式或算法参数简介 4.MATLAB核心程序 5.算法涉及理论知识概要 6.参考文献 7.完整算法代码文件获得 1.引言 Polar码由土耳其教授Erdal Arikan于2008年提出,是第一种被严格证明可以达到香农极限的构造性编码方法。其核…

Glide NoResultEncoderAvailableException异常解决

首先将解决方法提出来:缓存策略DiskCacheStrategy.DATA。 使用Glide加载图片,版本是4.15.0,有天发现无法显示gif图片,原始代码如下: Glide.with(context).load(本地资源路径).diskCacheStrategy(DiskCacheStrategy.A…

无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌

一、方案核心价值‌ ‌实时AI处理‌:6TOPS NPU实现无人机影像的实时缺陷检测(延迟<50ms)‌全国产化‌:芯片、操作系统、算法工具链100%自主可控‌极端环境适配‌:-40℃~85℃稳定运行,IP65防护等…

相机--相机成像原理和基础概念

教程 成像原理 基础概念 焦距(物理焦距) 镜头的光学中心到感光元件之间的距离,用f表示,单位:mm;。 像素焦距 相机内参矩阵中的 fx​ 和 fy​ 是将物理焦距转换到像素坐标系的产物,可能不同。…

2025-0604学习记录17——文献阅读与分享(2)

最近不是失踪了!也不是弃坑了...这不是马上要毕业了嘛!所以最近在忙毕业论文答辩、毕业去向填报、户档去向填报等等,事情太多了,没顾得上博客。现在这些事基本上都解决完了,也有时间静下心来写写文字了~ 想要写的内容…

图解浏览器多进程渲染:从DNS到GPU合成的完整旅程

目录 浅谈浏览器进程 浏览器进程架构的演化 进程和线程关系图示 进程(Process) 线程(Thread) 协程(Coroutine) 进程&线程&协程核心对比 单进程和多进程浏览器 单进程浏览器​编辑 单进程…

【计算机网络】第3章:传输层—TCP 拥塞控制

目录 一、PPT 二、总结 TCP 拥塞控制详解 ⭐ 核心机制与算法 1. 慢启动(Slow Start) 2. 拥塞避免(Congestion Avoidance) 3. 快速重传(Fast Retransmit) 4. 快速恢复(Fast Recovery&…

idea不识别lombok---实体类报没有getter方法

介绍 本篇文章,主要讲idea引入lombok后,在实体类中加注解Data,在项目启动的时候,编译不通过,报错xxx.java没有getXxxx()方法。 原因有以下几种 1. idea没有开启lombok插件 2. 使用idea-2023…

SAP学习笔记 - 开发15 - 前端Fiori开发 Boostrap,Controls,MVC(Model,View,Controller),Modules

上一章讲了Fiori开发的准备,以及宇宙至简之HelloWorld。 SAP学习笔记 - 开发14 - 前端Fiori开发 HelloWorld-CSDN博客 本章继续学习 Fiori 开发的知识: Bootstrap,Controls,MVC(Model,View,Controller&a…

基于SDN环境下的DDoS异常攻击的检测与缓解

参考以下两篇博客,最后成功: 基于SDN的DDoS攻击检测和防御方法_基于sdn的ddos攻击检测与防御-CSDN博客 利用mininet模拟SDN架构并进行DDoS攻击与防御模拟(Ryumininetsflowpostman)_mininet模拟dos攻击-CSDN博客 需求 H2 模拟f…

如何轻松地将文件从 PC 传输到 iPhone?

传统上,您可以使用 iTunes 将文件从 PC 传输到 iPhone,但现在,使用 iTunes 已不再是唯一的选择。现在有多种不同且有效的方法可以帮助您传输文件。在今天的指南中,您可以找到 8 种使用或不使用 iTunes 传输文件的方法,…

Bresenham算法

一 Bresenham 绘直线 使用 Bresenham 算法,可以在显示器上绘制一直线段。该算法主要思想如下: 1 给出直线段上两个端点 ,根据端点求出直线在X,Y方向上变化速率 ; 2 当 时,X 方向上变化速率快于 Y 方向上变化速率&am…

【从GEO数据库批量下载数据】

从GEO数据库批量下载数据 1:进入GEO DataSets拿到所需要下载的数据的srr.list,上传到linux, 就可以使用prefetch这个函数来下载 2:操作步骤如下: conda 安装sra-tools conda create -n sra-env -c bioconda -c co…

day 44

使用DenseNet预训练模型对cifar10数据集进行训练 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms, models from torch.utils.data import DataLoader import matplotlib.pyplot as plt import os# 设置中文字体…

NER实践总结,记录一下自己实践遇到的各种问题。

更。 没卡,跑个模型休息好几天,又闲又急。 一开始直接套用了别人的代码进行实体识别,结果很差,原因是他的词表没有我需要的东西,我是用的医学文本。代码直接在github找了改的,用的是BERT的Chinese版本。 然…

微信小程序实现运动能耗计算

微信小程序实现运动能耗计算 近我做了一个挺有意思的微信小程序,能够实现运动能耗的计算。只需要输入性别、年龄、体重、运动时长和运动类型这些信息,就能算出对应的消耗热量。 具体来说,在小程序里,性别不同,身体基…

iTunes 无法备份 iPhone:10 种解决方法

Apple 设备是移动设备市场上最先进的产品之一,但有些人遇到过 iTunes 因出现错误而无法备份 iPhone 的情况。iTunes 拒绝备份 iPhone 时,可能会令人非常沮丧。不过,幸运的是,我们有 10 种有效的方法可以解决这个问题。您可以按照以…

LangChain4J 使用实践

这里写目录标题 大模型应用场景&#xff1a;创建一个测试示例AIService聊天记忆实现简单实现聊天记录记忆MessageWindowChatMemory实现聊天记忆 隔离聊天记忆聊天记忆持久化 添加AI提示词 大模型应用场景&#xff1a; 创建一个测试示例 导入依赖 <dependency><groupI…

【C++】—— 从零开始封装 Map 与 Set:实现与优化

人生的态度是&#xff0c;抱最大的希望&#xff0c;尽最大的努力&#xff0c;做最坏的打算。 —— 柏拉图 《理想国》 目录 1、理论基石——深度剖析 BSTree、AVLTree 与 RBTree 的概念区别 2、迭代器机制——RBTree 迭代器的架构与工程实现 3、高级容器设计——Map 与 Set…