Ana içeriğe geç

Bir Mnemonikten Anahtar Çifti Nasıl Geri Yüklenir

Birçok cüzdan uzantısı gizli anahtarlarını temsil etmek için mnemonikleri kullanır. Mnemonikleri yerel testler için anahtar çiftlerine dönüştürebilirsiniz.

BIP39 formatındaki mnemonikleri geri yüklemek

bilgi

BIP39 mnemonikleri, kullanıcıların özel anahtarlarını kolayca yedeklemelerine ve geri yüklemelerine olanak tanır.

import { Keypair } from "@solana/web3.js";
import * as bip39 from "bip39";

const mnemonic =
"pill tomorrow foster begin walnut borrow virtual kick shift mutual shoe scatter";

// arguments: (mnemonic, password)
const seed = bip39.mnemonicToSeedSync(mnemonic, "");
const keypair = Keypair.fromSeed(seed.slice(0, 32));

console.log(`${keypair.publicKey.toBase58()}`);

// output: 5ZWj7a1f8tWkjBESHKgrLmXshuXxqeY9SYcfbshpAqPG
ipucu

bip39.mnemonicToSeedSync fonksiyonu, mnemonikten bir tohum oluşturmak için kullanılır. Bu tohum, anahtar çiftinin oluşturulmasında kritik bir rol oynar.

BIP44 formatındaki mnemonikleri geri yüklemek

not

BIP44, çoklu hesap ve alt hesap yapısına izin vererek birden fazla varlık yönetimini kolaylaştırır.

import { Keypair } from "@solana/web3.js";
import { HDKey } from "micro-ed25519-hdkey";
import * as bip39 from "bip39";

const mnemonic =
"neither lonely flavor argue grass remind eye tag avocado spot unusual intact";

// arguments: (mnemonic, password)
const seed = bip39.mnemonicToSeedSync(mnemonic, "");
const hd = HDKey.fromMasterSeed(seed.toString("hex"));

for (let i = 0; i < 10; i++) {
const path = `m/44'/501'/${i}'/0'`;
const keypair = Keypair.fromSeed(hd.derive(path).privateKey);
console.log(`${path} => ${keypair.publicKey.toBase58()}`);
}
tehlike

Anahtar çiftlerini geri yüklerken doğru path yapısının kullanıldığından emin olun. Yanlış bir path, istenmeyen sonuçlara yol açabilir.

:::quote "BIP39 ve BIP44, şifreleme ve anahtar yönetimi alanında standartlar oluşturarak, kullanıcıların güvenli bir şekilde varlıklarını yönetmelerine olanak tanır." — Dünya Kripto Uzmanı :::