区块链钱包是用户进入 Web3 世界的第一站。要理解钱包的功能,首先要抛开“钱包=资产”的传统观念,真正认识它在去中心化世界中的角色:私钥管理器 + 用户身份认证器。
📚 作者:Henry 🧱 系列:《区块链钱包原理与前端集成实践》 · 第 1 篇 👨💻 受众:Web3 开发者 / 区块链学习者 👉 系列持续更新中,建议收藏专栏或关注作者
区块链钱包 ≠ 存放资产
区块链钱包 = 控制私钥 + 发起签名
区块链资产(如 ETH、ERC-20)是“记录在链上的数据”,不在你的钱包里,而是在一个地址上。
钱包的功能核心在于:
🔍 私钥生成地址,地址持有资产,钱包控制私钥,因此钱包可控制资产。
项目 | EOA | 合约钱包 |
---|---|---|
控制方式 | 私钥 | 智能合约逻辑 |
是否支持签名 | ✅ | 需合约实现 EIP-1271 |
是否可被升级 | ❌ | ✅(可 Proxy) |
Gas 支付方式 | 自付 | 可由他人代付(Paymaster) |
类别 | 是否联网 | 是否持私钥 | 推荐场景 |
---|---|---|---|
热钱包 | 是 | ✅ | 高频交易、日常交互,风险高 |
冷钱包 | 否 | ✅ | 长期存储、高安全性 |
托管钱包 | 是 | ❌ | 新用户、小额场景 |
非托管钱包 | 是/否 | ✅ | Web3 爱好者、链上开发者 |
钱包 | 类型 | 适用链 | 特点 |
---|---|---|---|
MetaMask | 热钱包(浏览器插件) | EVM | 最广泛使用,支持 Injected Provider |
Rainbow | 热钱包(移动端) | EVM | UI 优雅,支持 WalletConnect |
Safe | 合约钱包 | EVM | 多签控制,适合 DAO / 机构 |
Phantom | 热钱包 | Solana | 支持 NFT 展示与 Swap |
Coinbase Wallet | 热钱包 | EVM / L2 | 支持 ENS、身份系统 |
approve
+ transferFrom
实现转账import { Wallet } from 'ethers';
const wallet = Wallet.createRandom();
console.log('地址:', wallet.address);
console.log('助记词:', wallet.mnemonic?.phrase); // 注意:v6 中为可选属性
console.log('私钥:', wallet.privateKey);
Wallet.createRandom()
用于生成新钱包mnemonic
现在是 Mnemonic | undefined
,建议使用可选链操作符访问如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!