智能合约开发中13种最常见漏洞及修复(精华版)

智能合约一旦部署便不可篡改,安全漏洞往往直接导致资产损失。本文提炼13种常见漏洞中最重要的8种,用最简洁的方式给出原理与核心修复方案。


1. 重入攻击

原理 :先转账后扣款,攻击者通过递归调用不断提款。

修复先更新状态,再转账

复制代码
balances[msg.sender] -= _amount;
msg.sender.transfer(_amount);

2. 整数溢出与下溢

原理 :数值超出范围时回绕(溢出归零,下溢变最大值)。

修复:使用 Solidity 0.8+ 内置检查,或 SafeMath。

复制代码
balance = balance + amount;  // 0.8+ 自动抛出异常

3. 未授权访问

原理 :提款、重置等关键函数未加权限限制。

修复:添加访问修饰器。

复制代码
modifier onlyOwner() { require(msg.sender == owner); _; }
function withdraw() public onlyOwner { ... }

4. 断言失败导致锁死

原理assert() 用于不可恢复的内部错误,一旦失败 Gas 全耗且资金可能永久锁定。

修复 :外部校验改用 require()

复制代码
// assert(msg.sender == owner)
require(msg.sender == owner, "Not owner");

5. 时间戳依赖

原理 :矿工可小幅度操纵 block.timestamp,影响博彩、截止时间等。

修复:用区块高度替代精确时间戳。

复制代码
deadline = block.number + blocksToWait;

6. Gas 耗尽与 DoS 攻击

原理 :无限循环或海量遍历耗尽调用方 Gas,导致交易回滚。

修复:限制循环次数,避免遍历动态数组。

复制代码
require(n <= 1000, "Loop limit");
for(uint i=0; i<n; i++) { ... }

7. 权限管理不当

原理 :管理员权限过大(如无限铸币),私钥泄露即灾难。

修复:分权、多签、日限额。

复制代码
require(dailyMinted + amount <= dailyLimit, "Over limit");

8. 存储与计算效率低下

原理 :数组动态扩容和全量遍历消耗巨额 Gas。

修复:用映射 + 计数器代替数组。

复制代码
// 映射加计数器
mapping(address => bool) public voted;
uint256 public totalVotes;

以上为精华版,本文原版共涵盖 13 种漏洞 ,包括短地址攻击、代理漏洞、随机数漏洞等,并附详细攻击演示与审计代码。

🔗 阅读完整版请访问: https://www.jay-r-j.top/smart-contract-vulnerabilities/

相关推荐
开开心心就好2 小时前
清理重复文件释放C盘空间的工具
安全·智能手机·pdf·gitlab·音视频·intellij idea·1024程序员节
@insist1232 小时前
系统架构设计师-区块链安全架构原理与安全系统设计实战
安全·系统架构·区块链·软考·软件水平考试
HackTwoHub2 小时前
关于文件上传漏洞深度绕过利用教程,突破命令执行限制
运维·安全·web安全·网络安全·系统安全·安全架构
醒醒该学习了!2 小时前
AI中的隐私、安全与合规(理论篇)
人工智能·安全
rayylee2 小时前
Asterinas 0.18.0 发布:迈向安全容器(Kata)与机密容器(CoCo)
安全
网安小白的进阶之路2 小时前
B模块 安全通信网络 第二门课IPv6与WLAN 05
网络·安全
一拳一个娘娘腔2 小时前
【开篇】揭开黑客的面纱:Web渗透测试全景指南与法律红线
web安全
超级无敌zhq2 小时前
内网权限维持实战:打造持久化后门与隐蔽通道
网络·windows·安全·网络安全
Tattoo_Welkin2 小时前
一些常用的金融和区块链的概念
金融·区块链