我需要向我的客户提供支付 ETH 地址,以便将 ETH 存入他们的账户。我想为此使用 HD ETH 钱包,我现在正在使用 Ledger Nano S。但是 Ledger 只显示了 1 个接收地址,所以我需要 ETH 钱包的 XPub 从中生成许多地址以分发给用户。
如果 Ledger 支持 HD,我如何导出 XPub?如果分类帐不支持,哪个钱包可以用于此目的。
有什么建议么。
我需要向我的客户提供支付 ETH 地址,以便将 ETH 存入他们的账户。我想为此使用 HD ETH 钱包,我现在正在使用 Ledger Nano S。但是 Ledger 只显示了 1 个接收地址,所以我需要 ETH 钱包的 XPub 从中生成许多地址以分发给用户。
如果 Ledger 支持 HD,我如何导出 XPub?如果分类帐不支持,哪个钱包可以用于此目的。
有什么建议么。
您不能使用默认的比特币或以太坊应用程序直接从账本 nano 中导出 xpub。
但是您可以使用从分类帐中提取的数据来构建 xpub。
您需要的是您感兴趣的 bip32 路径的公钥和链码以及该路径的父路径的公钥。
在以太坊应用程序中,您将使用getaddress(目前此应用程序对 m/44/60'、m/44'/61' 和 m/44'/1' 及以下有限制(我有一个问题希望消除该限制)。在比特币应用程序中,您将使用getwalletpublickey。比特币应用程序中没有 bip32 路径限制。
一旦你有了两个公钥和链码,你就可以构建 xpub。这是一块可以完成此任务的python。它使用未维护的 pybitcointools,因此请注意用户。
#!/usr/bin/env python
import sys
import binascii
from bitcoin import bin_hash160
from bitcoin import bip32_serialize
from bitcoin import compress
def main(parent_pubkey, pubkey, chaincode, depth, index, network):
if (network.lower() == "main"):
network_bytes = b'\x04\x88\xb2\x1e'
elif (network.lower() == "test"):
network_bytes = b'\x04\x35\x87\xcf'
else:
sys.exit("network must be either main or test")
compressed_pubkey_bytes = binascii.unhexlify(compress(pubkey))
fingerprint_bytes = bin_hash160(binascii.unhexlify(compress(parent_pubkey)))[:4]
chaincode_bytes = binascii.unhexlify(chaincode)
deserialized = (network_bytes, int(depth), fingerprint_bytes, int(index), chaincode_bytes, compressed_pubkey_bytes)
xpub = bip32_serialize(deserialized)
print(xpub)
if __name__ == '__main__':
if (len(sys.argv) < 7):
sys.exit("USAGE: generate_xpub PARENT_PUBLICKEY PUBLICKEY CHAINCODE DEPTH INDEX (MAIN|TEST)")
main(sys.argv[1], sys.argv[2], sys.argv[3], sys.argv[4], sys.argv[5], sys.argv[6])