如何使用Java为以太坊生成确定性密钥?

Ita*_*tto 0 java cryptography bitcoinj ethereum

我正在尝试为以太坊混合BitcoinJ和创建一个确定性钱包Web3j。确定性密钥使用生成BitcoinJ,以太坊凭证使用生成Web3j。但是用Web3j凭证生成的地址与预期的不一样。

String seedCode = "yard impulse luxury drive today throw farm pepper survey wreck glass federal";

// BitcoinJ
DeterministicSeed seed = new DeterministicSeed(seedCode, null, "", 1409478661L);
DeterministicKeyChain chain = DeterministicKeyChain.builder().seed(seed).build();
DeterministicKey key = chain.getKey(KeyPurpose.RECEIVE_FUNDS);
BigInteger privKey = key.getPrivKey();

// Web3j
Credentials credentials = Credentials.create(privKey.toString(16));
System.out.println("Address: " + credentials.getAddress());
Run Code Online (Sandbox Code Playgroud)

输出0x2c4186d0422d0462a48c92cd559cbc30f528855b

预期0x72445fcFdEB1Fff79496D7Ce66089d663Ff90E26

代码中的误解在哪里?

Ita*_*tto 5

默认情况下,bitcoinj使用m/0'/0密钥链的路径。和大多数的复仇方案用途m/44'/60'/0'/0BIP44规范。这就是为什么与其他以太坊工具相比结果不如预期的原因。

下面的代码解决了“问题”:

String seedCode = "yard impulse luxury drive today throw farm pepper survey wreck glass federal";

// BitcoinJ
DeterministicSeed seed = new DeterministicSeed(seedCode, null, "", 1409478661L);
DeterministicKeyChain chain = DeterministicKeyChain.builder().seed(seed).build();
List<ChildNumber> keyPath = HDUtils.parsePath("M/44H/60H/0H/0/0");
DeterministicKey key = chain.getKeyByPath(keyPath, true);
BigInteger privKey = key.getPrivKey();

// Web3j
Credentials credentials = Credentials.create(privKey.toString(16));
System.out.println(credentials.getAddress());
Run Code Online (Sandbox Code Playgroud)