关于区块链的助记词以及BTC地址,私钥,公钥,ETH地址获取的方法

VUE项目中的获取助记词的方式

安装需要的依赖环境

如果你安装了国内的淘宝镜像了 ,建议你用cnpm
bip39:npm install bip39
bip32:npm install bip32
ethereumjs-util:npm install ethereumjs-util
bitcoinjs-lib:npm install bitcoinjs-lib
这个我不知道怎么回事,安装不上需要python环境,这个是别人给弄得
代码如下:

var bitcoin = require('bitcoinjs-lib')
var bip39 = require('bip39')
var bip32 = require('bip32')
var ethUtil = require("ethereumjs-util");

var mnemonic = bip39.generateMnemonic()
// 存到localStorage中单词
var mnemonicArr = mnemonic.replace(/\s+/g, ',').split(',');
localStorage.setItem('mnemonic', JSON.stringify(mnemonicArr))
// console.log("助记词:" + mnemonic)

var seedHex = bip39.mnemonicToSeedHex(mnemonic);
// console.log(seedHex);
var seed = bip39.mnemonicToSeed(mnemonic)
// console.log(seed)
var seedAsHex = seed.toString('hex');

// 存到localStorage中bip39种子
localStorage.setItem('seed', JSON.stringify(seedAsHex))
// console.log("种子:" + seedAsHex);


var masterKey = bitcoin.HDNode.fromSeedHex(seed, bitcoin.networks.bitcoin)
// console.log("BTC");


// 存到localStorage中bip39种子
localStorage.setItem('masterKey', JSON.stringify(masterKey.toBase58()))
// console.log("root Key:" + masterKey.toBase58())


var bip32ExtendedKey = masterKey.derivePath("m/44'/0'/0'/0");
// console.log("btc:BIP32 Extended Private Key:" + bip32ExtendedKey.toBase58())


var key = bip32ExtendedKey.derive(0);
// console.log(key);
var keyPair = key.keyPair;
// console.log(keyPair);
var address = keyPair.getAddress().toString();
//  存到localStorage中btc公钥还有密钥
localStorage.setItem('BTCaddress', JSON.stringify(address))
// console.log("btc地址:" + address);
var privkey = keyPair.toWIF();
//  存到localStorage中btc私钥
localStorage.setItem('privBTC', JSON.stringify(privkey))
// console.log("btc私钥:" + privkey);
var pubkey = keyPair.getPublicKeyBuffer().toString('hex');
localStorage.setItem('publBTC', JSON.stringify(pubkey))
// console.log("btc公钥:" + pubkey);



var bip32ExtendedKey = masterKey.derivePath("m/44'/60'/0'/0");
// console.log("ETH:BIP32 Extended Private Key:" + bip32ExtendedKey.toBase58())
key = bip32ExtendedKey.derive(0);

// console.log(key);

var keyPair = key.keyPair;
var address = keyPair.getAddress().toString();
var privkey = keyPair.toWIF();
var pubkey = keyPair.getPublicKeyBuffer().toString('hex');
var privKeyBuffer = keyPair.d.toBuffer(32);
privkey = privKeyBuffer.toString('hex');
var addressBuffer = ethUtil.privateToAddress(privKeyBuffer);
address = ethUtil.addHexPrefix(ethUtil.toChecksumAddress(ethUtil.privateToAddress(privKeyBuffer).toString('hex')));
privkey = ethUtil.addHexPrefix(privkey);
pubkey = ethUtil.addHexPrefix(pubkey);
// eth的公钥私钥 地址
localStorage.setItem('ETHaddress', JSON.stringify(address))
localStorage.setItem('publETH', JSON.stringify(privkey))
localStorage.setItem('privETH', JSON.stringify(pubkey))
// 
// console.log("ETh地址:" + address);
// console.log("ETh私钥:" + privkey);
// console.log("ETh公钥:" + pubkey);

参考文章:廖雪峰大神的博客网站

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ECC椭圆曲线在比特币中被用于加密和签名交易。以下是计算出比特币公钥的过程: 1. 选择椭圆曲线和基点 比特币使用的是secp256k1椭圆曲线,其基点为G。这个基点是一个预设的点,固定在曲线上。基点的坐标是一个大整数,用十六进制表示为: ``` G = 04 79BE667E F9DCBBAC 55A06295 CE870B07 029BFCDB 2DCE28D9 59F2815B 16F81798 483ADA77 26A3C465 5DA4FBFC 0E1108A8 FD17B448 A6855419 9C47D08F FB10D4B8 ``` 2. 选择私钥 私钥是一个随机数,通常是由计算机生成。私钥通常由256位二进制数表示,可以用十六进制表示。比特币私钥的范围是1到约2^256-1。 3. 计算公钥 公钥是由私钥通过椭圆曲线算法计算出来的。计算公钥的过程是: - 将私钥表示为一个大整数d - 通过基点G和私钥d计算出公钥Q 计算公式为: ``` Q = d * G ``` 这个公式表示将基点G与一个标量d相乘,得出的结果就是公钥Q。在比特币中,公钥通常用压缩格式表示,即只保留x坐标和一个标记位,表示y坐标的符号。 4. 生成比特币地址 比特币地址是由公钥生成的。比特币地址通常以1或3开头,表示这是一个Pay-to-PubkeyHash(P2PKH)或Pay-to-ScriptHash(P2SH)地址。生成地址的过程是: - 对公钥进行哈希处理,生成一个哈希值 - 将哈希值进行Base58Check编码,得到比特币地址 注意:在比特币中,P2PKH地址是最常用的地址类型。P2SH地址通常用于多重签名和其他高级功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值