gpt4 book ai didi

rust - 如何从 secp256k1 中提取未压缩的公钥?

转载 作者:行者123 更新时间:2023-12-03 11:46:31 24 4
gpt4 key购买 nike

编辑:对问题进行了大量编辑以缩小问题的焦点
我正在尝试从 secp256k1::key::PublicKey 中提取未压缩的公钥。结构。
根据我使用的打印格式,我可以获得压缩或未压缩的 key 。
正如 question 所观察到的那样,解压后的key是hex-(或byte-)反转的(可以看到压缩版本的反转就是解压版本的开始)。
我不知道如何从结构中提取 64 字节(反转)键来操作它。如果我尝试使用 .serialize()公钥上的方法,它返回压缩 key 的 33 字节切片,而不是公钥。
有谁知道如何从结构中提取和操作 64 字节 key ?
下面的代码片段:

//Calculate BIP32 Extended Public Key and Public Key
let ex_pub_key = ExtendedPubKey::from_private(&secp, &ex_priv_key);
println!("Compressed Public Key: {}", ex_pub_key.public_key.key);
//returns the 33-byte:
//03a593ae00ed6b402c801d2a2edca9f5c057f2be7327e3d81c5747df058e169cd5

println!("Uncompressed Public Key: {:?}", ex_pub_key.public_key.key);
//returns the 64-byte struct:
//PublicKey(d59c168e05df47571cd8e32773bef257c0f5a9dc2e2a1d802c406bed00ae93a57d95dc0fa554e33bda9c7cd87e4b8e8b788b759c0bb1160bb803240468d0e559)

//Serializing the key returns the compressed version of the key
let serialized_key = public_key.serialize();
println!("Serialized Key: {:?}", serialized_key);
//returns the 33-byte slice:
//[3, 165, 147, 174, 0, 237, 107, 64, 44, 128, 29, 42, 46, 220, 169, 245, 192, 87, 242, 190, 115, 39, 227, 216, 28, 87, 71, 223, 5, 142, 22, 156, 213]

最佳答案

经过大量研究,我发现有一种简单的方法可以使用 serialize_uncompressed() 方法提取未压缩的公钥。在公共(public) key 上,它是同一 secp256k1 的一部分箱。
这提供了一个 65 字节的输出,其中第一个字节应该被删除以创建正确的 64 字节公钥。

关于rust - 如何从 secp256k1 中提取未压缩的公钥?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66383584/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com