通过plasmo的wallet扩展添加新钱包

typescript 复制代码
//添加bip39库、zustand库、ethers
pnpm add bip39
pnpm add zustand
pnpm add ethers

全局状态管理zustand,管理钱包助记词和私钥:

typescript 复制代码
//新增stores\wallet.ts文件
import * as bip39 from 'bip39';
import { HDNodeWallet } from 'ethers';
import { create } from 'zustand';

interface WalletStore {
  mnemonic: string | null
  address: string | null
  wallet: HDNodeWallet | null
  setMnemonic: (mnemonic: string | null) => void
  setAddress: (address: string | null) => void
  createWallet: () => Promise<void>
}

const DEFAULT_DERIVATION_PATH = "m/44'/60'/0'/0/0"

export const useWalletStore = create<WalletStore>((set) => ({
  address: null,
  mnemonic: null,
  wallet: null,
  setMnemonic: (mnemonic) => set({ mnemonic }),
  setAddress: (address) => set({ address }),
  createWallet: async () => {
    const mnemonic = await bip39.generateMnemonic(128)
    set({ mnemonic })
    const wallet = HDNodeWallet.fromPhrase(
      mnemonic,
      "",
      DEFAULT_DERIVATION_PATH
      )
      const walletObj = {...wallet, privateKey: wallet.privateKey}
    set({ wallet: walletObj as HDNodeWallet })
  }
}))

在popup.tsx中,点击按钮即可生成新钱包,可以去小狐狸上添加验证。

typescript 复制代码
import { useWalletStore } from "~stores/wallet";

function IndexPopup() {

  const { createWallet, wallet } = useWalletStore()

  return (
    <div className="plasmo-flex plasmo-items-center plasmo-justify-center plasmo-h-16 plasmo-w-40">
      <button onClick={async () => await createWallet()}>创建钱包</button>
      <div>{JSON.stringify(wallet)}</div>
    </div>
  )
}

export default IndexPopup

一些相关理论:

typescript 复制代码
通过BIP39协议生成助记词:
1.通过generateMnemonic API 生成一段128位的二进制随机数,即Entropy(熵)。
2.对熵进行哈希运算,截取前4位,作为校验和
3.组合熵和校验和,形成132位的二进制数。
4.分成12段,每一段是11位。
5.每一段对应词库里的一个单词,最终可以形成12个单词。(如果最开始是生成256位的二进制随机数,那么就能得到24个单词)

BIP44 派生路径: m/44'/60'/0'/0/0
m:HD树的根节点,master
44':表示BIP44协议
60':当前代币类型,60代表的是以太坊
0':账户的索引,第0个账户
0:外部链/内部链,0代表外部收款地址,在链上暴露,可以用来收款。1代表内部链,不暴露,用来找零
0:钱包地址的索引
相关推荐
Rain509几秒前
2.1 Nest.js 项目初始化与模块化架构
开发语言·前端·javascript·后端·架构·数据分析·node.js
拾年2751 小时前
从零手写 Ajax:用原生 XHR 搭建前后端交互全流程
前端·javascript·ajax
东方隐侠安全团队-千里1 小时前
币安Skills Hub:散户的“机构级超能力“来了
安全·ai·区块链·skills
拉勾科研工作室1 小时前
区块链工程毕业论文题目【249个】
开发语言·javascript
终端域名1 小时前
AI与区块链融合:加密货币的下一前沿——技术架构、企业价值与未来趋势
人工智能·架构·区块链
小林ixn1 小时前
你以为你懂 + 号?看完这篇 Bun + TS 实战,才发现以前全写错了
前端·javascript·typescript
Richown1 小时前
区块链治理:DAO与去中心化治理机制
区块链·react
终端域名1 小时前
密码学哈希函数:区块链 “不可篡改” 的核心数字指纹技术
区块链·密码学·哈希算法
jvxiao3 小时前
你真的懂作用域吗?从编译原理角度深度 JS 的作用域
前端·javascript
Darling噜啦啦3 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构