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

两种钱包之非确定性钱包(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

    比特币

    $ 63669.74¥ 436965.42
    -5.54%
  • ethereum ETH 以太坊

    ETH

    以太坊

    $ 1854.6¥ 12728.11
    -7.96%
  • tether USDT 泰达币

    USDT

    泰达币

    $ 1.0005¥ 6.8664
    +0.04%
  • binance-coin BNB 币安币

    BNB

    币安币

    $ 592¥ 4062.89
    -5.25%
  • ripple XRP 瑞波币

    XRP

    瑞波币

    $ 1.2772¥ 8.7654
    -9.29%
  • usdc USDC USD Coin

    USDC

    USD Coin

    $ 1.0017¥ 6.8746
    +0.15%
  • solana SOL Solana

    SOL

    Solana

    $ 78.442¥ 538.34
    -9.21%
  • tron TRX 波场

    TRX

    波场

    $ 0.2795¥ 1.9182
    -1.93%
  • dogecoin DOGE 狗狗币

    DOGE

    狗狗币

    $ 0.08833¥ 0.6062
    -9.28%
  • cardano ADA 艾达币

    ADA

    艾达币

    $ 0.2608¥ 1.7898
    -10.32%

币圈快讯

  • DeFianceCapital创始人:加密货币已成为周末避险事件中首选的做空对冲工具

    2026-02-28 18:29
    DeFianceCapital创始人Arthur在X平台发文表示,加密货币现在已成为传统金融在周末任何避险事件中首选的做空对冲工具,并对此感到遗憾。
  • Arthur:加密货币不幸成为周末避险事件中首选的做空对冲工具

    2026-02-28 18:23
    DeFianceCapital创始人Arthur表示,很不幸,加密货币成为周末避险事件中首选的做空对冲工具。
  • BTC与ETH最大多头持仓合计亏超1300万美元暂未减仓

    2026-02-28 18:20
    据HyperInsight监测,受市场回落影响,BTC与ETH两大币种最大多头巨鲸浮亏扩大,两者合计亏超1,300万美元,截至发稿暂未平仓减仓,其持仓主要信息如下:“pension-usdt.eth”:3倍杠杆BTC多单规模达6,360万美元,均价6.68万美元,浮亏317万美元(15%);“ETH波段大师”:15倍杠杆ETH多单规模达1.29亿美元,均价1,991美元,浮亏约960万美元(-110%);
  • 伊朗最高国家安全委员会:已就美以军事行动予以回应

    2026-02-28 18:19
    据伊朗媒体2月28日报道,伊朗最高国家安全委员会发布第1号公告称,伊朗武装部队已对美国和以色列的军事行动予以坚决回应。
  • 阿联酋弹片坠落导致一名亚裔人士死亡

    2026-02-28 18:13
    据阿联酋国家通讯社报道,该国有关部门处理了阿布扎比市居民区发生的弹片坠落事件,该事件造成了一些物质损失,并导致一名亚洲国籍人士死亡。
  • 查看更多