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
代码中的误解在哪里?
默认情况下,bitcoinj使用m/0'/0密钥链的路径。和大多数的复仇方案用途m/44'/60'/0'/0从BIP44规范。这就是为什么与其他以太坊工具相比结果不如预期的原因。
下面的代码解决了“问题”:
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)