当前位置:主页 > 区块链 > 区块链技术 > 非确定性钱包介绍

两种钱包之非确定性钱包(keystore管理私钥)

2026-02-28 12:36:50 | 来源: | 作者:佚名
本文讲解非确定性钱包,因为比较简单,下面会直接给出代码实现,下一篇文章会详细讲解分层确定性钱包,这个已经成为了行业标准,我会重磅介绍,并对比两种钱包的适用场景

以太坊上有 2 种钱包:

  • 非确定性钱包,也叫随机钱包,每个账户通过独立的随机数生成器创建,使用keystore管理账户,没有助记词
  • 分层确定性钱包,也叫HD Wallet,每个账户通过固定的种子(seed)派生,使用助记词管理所有账户。

本文讲解非确定性钱包,因为比较简单,下面会直接给出代码实现。下一篇文章会详细讲解分层确定性钱包,这个已经成为了行业标准,我会重磅介绍,并对比两种钱包的适用场景。

概念

随机数生成器:如Web3专题(一) 助记词和生成私钥、公钥、地址的基本原理所说,私钥是 256 位随机数字,需要使用安全的随机源生成,并经过一系列算法生成公钥、地址。

keystore:是一种文件格式,称为存储机制,主要目的是提供一种安全的方式来保管私钥,需要用户提供密码来解锁私钥。

通常,用 keystore 文件加密私钥等信息,来保护非确定性钱包

使用 Go 语言开发一个非确定性钱包

  • 需要引入的包
import (
	"github.com/ethereum/go-ethereum/accounts/keystore"
	"github.com/ethereum/go-ethereum/common"
	"github.com/ethereum/go-ethereum/crypto"
)
  • 创建 keystore 对象,所有的私钥都由这个 keystore 对象管理。在这里,我们指定./keystore文件夹保存账户。

特别提醒
NewKeyStore 方法只会加载目录,并监控目录的变化,不会创建账户,创建账户在下面第 3 步。
NewKeyStore 方法内部会自动扫描./keystore文件夹,并加载这个文件夹下的所有账户到 keystore 对象

// 第一个参数:./keystore 指定账户所在的文件夹
ks := keystore.NewKeyStore("./keystore", keystore.StandardScryptN, keystore.StandardScryptP)
  • 创建一个新账户

NewAccount 会利用你指定的密码在./keystore 目录下创建一个 json 文件,这个文件包含了加密过的私钥、公钥、地址等。
每执行一次 NewAccount 都会创建一个新账户。因此,如果只需要加载已有账户,则不需要执行这个方法。
所有的 json 文件都会存放在./keystore 文件夹。

acc, err := ks.NewAccount("your password")
if err != nil {
    panic(err)
}
  • 获取已创建的账户,会从./keystore 文件夹内拿到所有账户

ks对象是第2步创建的,会自动扫描./keystore 文件夹,拿到所有账户。

for _, acc := range ks.Accounts() {
    fmt.Println("账户地址:", acc.Address.String())
}
  • 如果希望签名交易的话,可以使用钱包
for _, wallet := range ks.Wallets() {
    // 这里每个钱包获得的第一个account和上面第4步的账户是一一对应的
    _, _ = wallet.SignTx(wallet.Accounts()[0], nil, nil)
    _, _ = wallet.SignData(wallet.Accounts()[0], "", nil)
}
  • 如果希望导出私钥,则需要密码才可以。PASSWORD是上面第3步创建新账户设置的密码。
// 先把账户的 json 文件导出为[]byte
kjson, err := ks.Export(ks.Accounts()[0], PASSWORD, PASSWORD)
if err != nil {
    panic(err.Error())
}
// 通过kjson+密码可以解密私钥
key, err := keystore.DecryptKey(kjson, PASSWORD)
if err != nil {
    panic(err.Error())
}
privateKey := key.PrivateKey
fmt.Println(common.BytesToHash(crypto.FromECDSA(privateKey)).String())

至此,我们已经学会了如何使用 Go 语言创建非确定性钱包

免责声明:本文只为提供市场讯息,所有内容及观点仅供参考,不构成投资建议,不代表本站观点和立场。投资者应自行决策与交易,对投资者交易形成的直接或间接损失,作者及本站将不承担任何责任。!

你可能感兴趣的文章

更多

热门币种

  • 币种
    最新价格
    24H涨跌幅
  • bitcoin BTC 比特币

    BTC

    比特币

    $ 74395.99¥ 507239.29
    +0.37%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 2358.59¥ 16081.1
    +1.9%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 1¥ 6.818
    -0.04%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.3862¥ 9.4512
    +2.32%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 622.41¥ 4243.65
    +1.33%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 0.9996¥ 6.8153
    +0.02%
  • solana SOL Solana

    SOL

    Solana

    $ 85.0125¥ 579.62
    +1.06%
  • tron TRX 波场

    TRX

    波场

    $ 0.3283¥ 2.2383
    +1.58%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.095183¥ 0.6489
    +2.09%
  • hyperliquid HYPE Hyperliquid

    HYPE

    Hyperliquid

    $ 44.7897¥ 305.38
    +3.87%

币圈快讯

  • 美CFTC主席:将惩罚欺诈和内幕交易

    2026-04-16 03:29
    4月16日,一份书面声明显示,美国商品期货交易委员会(CFTC)主席MichaelSelig将在美国国会承诺,将惩罚欺诈和内幕交易。CFTC主席表示:“我们会找到你,你将面临法律的全部制裁。”
  • 白宫:特朗普将提交“美国凯旋拱门”建设计划

    2026-04-16 03:29
    4月16日,白宫新闻秘书卡罗琳·莱维特当地时间4月15日表示,美国总统特朗普与内政部将提交建设“美国凯旋拱门”的规划方案,以纪念美国建国250周年。莱维特称,该建筑拟高250英尺,选址于华盛顿特区波托马克河上的哥伦比亚岛纪念环岛区域,将由国家公园管理局管理。项目计划配备艺术雕塑与历史展示内容,用以呈现美国250年来的发展与成就。她表示,该项目计划于今年启动建设,并作为独立日及建国250周年系列庆祝活动的一部分,未来还将公布更多相关安排。(央视新闻)
  • 美国发布新一轮涉伊制裁措施

    2026-04-16 03:29
    4月16日,当地时间15日,美国财政部网站发布了新一轮涉伊及反恐制裁措施,将3名个人、17个实体以及9艘船只列为制裁对象。(央视新闻)
  • Alphabet有望从其对SpaceX的投资中获得约1000亿美元的巨额回报

    2026-04-16 03:29
    4月16日,市场消息:谷歌母公司Alphabet有望从其对SpaceX的投资中获得约1000亿美元的巨额回报。
  • 以军为与黎巴嫩达成停火协议设定三个基本条件

    2026-04-16 03:21
    4月16日,当地时间15日晚,据以色列方面消息,以色列军方为与黎巴嫩达成停火协议设定了三个基本条件:以色列军方要求建立一个延伸至利塔尼河的缓冲区并禁止黎巴嫩真主党在该区域活动;以军要求在利塔尼河以北地区采取完全的军事行动自由,旨在消除以方面临的威胁;以军要求在美方监督下,通过长期步骤解除黎巴嫩真主党武装。(央视新闻)
  • 查看更多