智能合约开发中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/

相关推荐
Flynt2 天前
npm v12 来了:allowScripts 默认关闭,我的项目差点跑不起来
安全·npm·node.js
Rockbean6 天前
10分钟智能合约:进阶实战-7.2 Foundry开发环境
web3·智能合约·solidity
冬奇Lab7 天前
Skill 系列(02):Skill 安全风险——三类攻击面的实战测试
人工智能·安全·开源
Rockbean9 天前
10分钟智能合约:进阶实战-6.4 使合约拒绝服务
web3·智能合约·solidity
Rockbean9 天前
10分钟智能合约:进阶实战-6.3 重入攻击提取资金
web3·智能合约·solidity
Aphasia31110 天前
VPN 与内网穿透
安全
木西11 天前
实战:基于 Solidity 0.8.27 与 OpenZeppelin V5 构建多链恶搞代币(以 SPX6900 为例)
web3·智能合约·solidity
Mr_愚人派11 天前
当"Claude"不再是 Claude:一次第三方 API 代理引发的 AI 身份伪造排查实录
人工智能·安全
DaLi Yao12 天前
【无标题】
人工智能·安全
Alsn8612 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker