以太坊 助记词提取 账户 公钥 私钥 最新实现可用。

step 1 装依赖的包(npm/yarn 自己选一个):

yarn add bip39 ethereumjs-wallet ethereumjs-util 
npm install bip39 ethereumjs-wallet ethereumjs-util

step 2 演示代码:

const bip39 = require('bip39')
const {hdkey} = require('ethereumjs-wallet')
const util = require('ethereumjs-util')

//1 生成助记词 ;1.1 和 1.2 自己按需。

// 1.1 生成助记词 ;这里用生成的.
// let mnemonic = bip39.generateMnemonic() 

// 1.2 生成助记词 ;这里用写死的.
let mnemonic = "hold scale hybrid tank dilemma bullet ship language attitude rug tennis host"
console.log(mnemonic)

//2.将助记词转成seed
getSeed = async ()=>{
    let seed = await bip39.mnemonicToSeed(mnemonic)
    console.log("seed:" + util.bufferToHex(seed))
    return seed
}
//3.提取私钥,公钥,账户
obtainAccount = async ()=>{
    let seed = await getSeed()
    //3.通过hdkey将seed生成HD Wallet
    let hdWallet = await hdkey.fromMasterSeed(seed)

    for (let i = 0; i < 10; i++) {
        //4.生成钱包中在m/44'/60'/0'/0/i路径的keypair
        let key = await hdWallet.derivePath("m/44'/60'/0'/0/" + i)
        //5.从keypair中获取私钥
        console.log("私钥:" + util.bufferToHex(key._hdkey._privateKey))
        //6.从keypair中获取公钥
        console.log("公钥:" + util.bufferToHex(key._hdkey._publicKey))
        //7.使用keypair中的公钥生成地址
        let address = await util.pubToAddress(key._hdkey._publicKey, true)
        //编码地址
        console.log('account',i+1,'0x'+address.toString('hex'))

//分割线        console.log("__________________________________________________________")
    }
}
obtainAccount()

step 3 运行结果截图:
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以太坊地址和公钥是通过椭圆曲线加密算法生成的。在以太坊中,每个账户都有一个唯一的以太坊地址和公钥以太坊公钥私钥也是通过椭圆曲线加密算法生成的。私钥用于对数据进行加密,公钥用于对数据进行解密。 下面是一个简单的示例,展示如何使用以太坊公钥私钥对数据进行加解密: 1. 生成公钥私钥以太坊中,可以使用任何一个以太坊钱包生成公钥私钥。例如,可以使用 MetaMask 钱包生成公钥私钥。 2. 加密数据 要加密数据,可以使用以太坊公钥私钥。以下是一个示例加密函数: ```solidity function encrypt(string memory message, address publicKey) public view returns (bytes32) { bytes32 encrypted = keccak256(abi.encodePacked(message, publicKey)); return encrypted; } ``` 在这个函数中,我们使用 keccak256 哈希函数对消息和公钥进行加密。 3. 解密数据 要解密数据,可以使用以太坊公钥私钥。以下是一个示例解密函数: ```solidity function decrypt(bytes32 encrypted, address privateKey) public view returns (string memory) { bytes32 decrypted = keccak256(abi.encodePacked(encrypted, privateKey)); return string(decrypted); } ``` 在这个函数中,我们使用 keccak256 哈希函数对加密后的消息和私钥进行解密。 请注意,这只是一个简单的示例,实际上在以太坊中使用公钥私钥进行加解密需要更多的安全措施和实现细节。建议在使用以太坊公钥私钥进行加解密时,始终遵循最佳实践和安全标准。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值