zhwanwan
网络钓鱼始于 20 世纪 90 年代,通过欺骗性电子邮件诱骗用户交出登录凭据。早期的网络犯罪分子以虚假的支持通知为目标,锁定 AOL 客户,窃取帐户密码和支付数据。后来演变成类似的诈骗,冒充 PayPal 和 eBay,警告用户虚假的帐户问题。到 2010 年代,犯罪分子发起了高度针对性的“商务电子邮件入侵”(BEC) 攻击:他们收集个人详细信息(通常来自社交媒体)以制作看起来像是来自高管或同事的电子邮件。这些量身定制的 BEC 诈骗非常有效,联邦调查局指出,网络钓鱼者经常包含准确的受害者信息(来自博客、社交网络等)以提高其合法性。简而言之,技术的每一次进步(从 AOL 帐户到公司电子邮件)都被网络钓鱼者迅速利用,以进行更具说服力的欺诈。 本专栏探索 Web3 中的网络钓鱼如何从旧式的电子邮件诈骗演变为今天的 deepfake AI 威胁、token drainers 和自动化的钱包定位黑客等,并进一步探索法律监管问题。
区块链取证方法、资金追踪、实用技术指南、归因技术以及利用多种信息源识别和追踪恶意行为者,高级取证技术如基于时间的交易关联、隐私协议的解混与去匿名化、跨链桥跳跃分析、大规模数据分析与查询、图分析与聚类、以及洗钱模式识别等
区块链桥梁是 web3 生态系统中的关键基础设施,支持不同区块链网络之间的跨链通信和资产转移。本系列将通过示例解释一些常见的/可能的桥梁智能合约漏洞。
使用的示例来自我过去的示例项目仓库 Blockchain-bridge-vulnerabilities。
本专栏主要整理区块链开发中需要注意的常见漏洞、安全注意事项、以及一些典型案例。如常见的钓鱼攻击、密码学风险、供应链攻击、虚假招聘、常见虚拟货币骗局、一些容易被忽视的安全问题等等。 目的是帮助开发者了解常见安全问题,提高警惕。
本专栏主要收集整理 2025 年的安全事件分析,帮助开发者了解历史安全事件及发生过程、并分析漏洞原因。 如2025年最典型的 Bybit 攻击事件、Mobius代币爆炸性漏洞利用、价值 1300 万美元的 Abracadabra GMX V2 漏洞攻击、12 万枚 BTC 失窃、NPM供应链攻击、12.8万美元的Zora空投漏洞利用 等
当你开始写复杂系统时,Rust 会逼你面对的那些设计抉择,Rust 真正强悍的地方,不只是“内存安全 + 速度快”。它更像一门把类型系统、抽象能力、约束表达、编译期推理推到很极致的语言。你可能每天都在写 Rust,却没怎么真正动用这些能力。
《小白的 Ethereum 源码解析征程》是一部从入门视角出发、逐步深入以太坊核心机制的源码学习笔记。专栏将以通俗语言带你阅读并理解以太坊的关键模块——从区块结构、账户与交易、共识机制到虚拟机(EVM)与状态存储,实现从“能跑懂”到“能改懂”的完整成长路径。无论你是刚入门区块链开发的新手,还是想真正看懂 Ethereum 内核的工程师,这里都是你的起点。
UniswapV2 技术深度解析项目
本项目基于 Solidity 0.8.30 与 Foundry 工具链,从零完整实现 UniswapV2 的生态系统,包括核心协议、外围组件、安全防护和高级特性,配套 23 篇系统化的中文教程文档。
本项目参照 Jeiwan 的 Programming DeFi: Uniswap V2 系列教程,结合现代 Solidity 开发最佳实践(Foundry + Solidity 0.8.30),为中文开发者提供完整的学习路径。
🌟 项目特色
🎉 项目完成状态
✅ 项目已完结 - 所有核心功能已实现,全部测试通过
已完成的核心模块
📊 项目统计
🚀 快速开始
环境要求
安装步骤
1. 安装 Foundry 工具链
curl -L https://foundry.paradigm.xyz | bash
foundryup
2. 克隆项目仓库
git clone https://github.com/RyanWeb31110/uniswapv2_tech
cd uniswapv2_tech
3. 安装依赖(OpenZeppelin 合约库和 Forge 标准库)
forge install
4. 编译所有合约
forge build
运行测试
运行所有测试(71 个测试用例)
forge test
查看测试覆盖率统计
forge test --summary
运行特定测试文件
forge test --match-contract UniswapV2PairTest
运行特定测试函数
forge test --match-test testMint
查看详细的 Gas 报告
forge test --gas-report
使用项目脚本运行测试(会在 logs/ 目录生成日志)
./scripts/test.sh
其他常用命令
格式化代码
forge fmt
检查代码格式
forge fmt --check
清理编译产物
forge clean
📁 项目架构
src/
├── core/ 🔷 核心协议层
│ ├── UniswapV2Factory.sol 工厂合约 - CREATE2 确定性部署
│ ├── UniswapV2Pair.sol 交易对合约 - AMM 核心逻辑
│ └── UniswapV2ERC20.sol LP 代币 - EIP-2612 支持
├── periphery/ 🔶 外围组件层
│ ├── UniswapV2Router.sol 路由合约 - 用户交互入口
│ └── WETH.sol 包装以太坊合约
├── libraries/ 📚 工具库集合
│ ├── UniswapV2Library.sol 核心计算库
│ ├── UQ112x112.sol 高精度定点数
│ └── StorageOptimization.sol 存储优化库
├── security/ 🔒 安全防护组件
│ └── ReentrancyGuard.sol 重入攻击防护
├── oracle/ 🔮 预言机系统
│ └── UniswapV2Oracle.sol TWAP 价格预言机
└── examples/ 💡 教学示例
├── ArbitrageBot.sol 套利机器人
└── LendingProtocol.sol 借贷协议
test/ 🧪 测试套件
├── core/ 核心协议测试
├── periphery/ 外围组件测试
├── security/ 安全防护测试
├── oracle/ 预言机系统测试
├── gas/ Gas 优化测试
└── mocks/ 测试辅助合约
docs/ 📖 系列教程文档(23篇完整版)
├── UniswapV2 深入解析系列 01:架构概述与开发环境搭建.md
├── UniswapV2 深入解析系列 02:流动性池机制与LP代币铸造.md
├── UniswapV2 深入解析系列 03:流动性移除机制与LP代币销毁.md
├── ... 完整的渐进式学习路径
├── UniswapV2 深入解析系列 22:重入防护与闪电贷安全.md
└── UniswapV2 深入解析系列 23:协议费用与系列总结.md
🎯 核心特性
🔷 核心协议层
🔶 外围组件层
🔒 安全防护系统
🔮 高级特性
📚 完整学习路径(23 篇系列教程)
🔰 基础篇(第 1-5 篇)
🔧 进阶篇(第 6-14 篇)
🚀 高级篇(第 15-23 篇)
💡 学习建议:建议按顺序阅读教程,每篇文章都配有完整的代码实现和测试用例,可以边学边实践。
⚡ 性能与优化
Gas 优化成果
完整测试套件
测试覆盖范围
✅ 核心协议层(32 测试):Pair 流动性管理、交换、闪电贷、费用机制
✅ 工厂合约(17 测试):交易对创建、地址计算、权限管理
✅ 外围组件(11 测试):Router 流动性操作、精确输入/输出兑换
✅ 安全防护(9 测试):重入攻击防护、恶意代币处理
✅ 预言机系统(12 测试):TWAP 累积价格计算、时间窗口查询
✅ 工具库(3 测试):价格计算、储备查询、路径管理
🛠 技术亮点与最佳实践
现代 Solidity 开发实践
安全防护机制
代码质量保证
🔄 与原版 Uniswap V2 的区别
| 现代化改进 | 特性 | 原版 Uniswap V2 (2020) | 本项目 (2024) |
|---|---|---|---|
| Solidity 版本 | 0.5.16 / 0.6.6 | 0.8.30 | |
| SafeMath | 必须使用 | 内置溢出检查,无需 SafeMath | |
| 错误处理 | require 字符串 |
自定义 error,节省 Gas |
|
| ERC20 实现 | 自己实现 | 使用 OpenZeppelin ERC20Permit | |
| 测试框架 | Truffle / Hardhat | Foundry(更快) | |
| 测试语言 | JavaScript | Solidity(类型安全) | |
| 代码注释 | 英文简洁注释 | 完整中文 NatSpec 注释 |
功能对比 ✅ 完整实现:
✨ 额外增强:
学习友好性
🎓 适用人群与学习收获
适合以下开发者
学完本项目你将掌握
📖 参考资源
官方文档
学习资源
相关项目
🤝 贡献与反馈
代码贡献流程
git checkout -b feature/your-featureforge testforge fmt文档贡献
反馈渠道
📜 许可证
本项目采用 MIT 许可证,详见 LICENSE 文件。
⚠️ 免责声明
本项目仅供学习和研究使用,未经过专业安全审计,请勿在生产环境或主网中直接部署使用。
🙏 致谢
如果本项目对你有帮助,欢迎 Star ⭐ 支持!
项目作者:RyanWeb31110
项目仓库:https://github.com/RyanWeb31110/uniswapv2_tech
本专栏详细介绍了跨链桥的工作原理,以Wormhole为例,解释了其内部机制、操作流程和面临的挑战。分析了跨链信息的处理,包括消息的创建、签名验证、代币转账等重要步骤,展现了跨链技术的复杂性和解决方案。
一共有四篇文章: 第一篇: 详细介绍了跨链桥的工作原理 第二篇:重点讨论了 Wormhole 跨链桥中验证 guardian 签名的机制
深入探讨 go-ethereum —— 以 Go 语言实现的以太坊执行客户端。
以太坊作为去中心化应用生态的核心支撑,其执行层客户端的实现逻辑是理解区块链运行机制的关键。go-ethereum作为采用 Go 语言实现的以太坊执行客户端,在研究以太坊底层技术时值得学习。
本专栏将以层层递进的方式,从Go的重要概念到交易执行流程再到字节码解释器的工作原理等等,逐步深入的带我们剖析了使用 Go 语言的以太坊执行客户端的实现。除了技术原理的剖析,专栏还将深入代码层面,带你品读 go-ethereum 的源码设计。从模块间的耦合与解耦,到设计模式的巧妙运用。通过技术原理与代码实现的深度绑定,帮助读者建立对以太坊执行层的完整技术认知
希望读者能够通过阅读本专栏,获得对 EVM 更深入的理解。
专栏目录: