微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决如何从 secp256k1 中提取未压缩的公钥?

编辑: 问题经过大量编辑以缩小问题的焦点

我正在尝试从 secp256k1::key::PublicKey 结构中提取未压缩的公钥。

根据我使用的打印格式,我会获得压缩或未压缩的密钥。

由此question观察到,未压缩的密钥是十六进制(或字节)反转的(您可以看到压缩版本的反转是未压缩版本的开始)。

我不知道如何从结构中提取 64 字节(反向)的键来操作它。如果我尝试对公钥使用 .serialize() 方法,它将返回压缩密钥的 33 字节切片,而不是公钥。

有谁知道如何从结构中提取和操作 64 字节的密钥?

以下代码片段:

//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,237,107,64,44,128,29,42,46,220,169,245,192,87,242,190,115,39,227,216,28,71,223,5,142,22,156,213]

解决方法

经过大量研究,我发现有一种简单的方法可以通过对公钥使用 serialize_uncompressed() 方法来提取未压缩的公钥,公钥是同一个 secp256k1 箱的一部分。

>

这提供了一个 65 字节的输出,其中第一个字节应该被删除以创建正确的 64 字节公钥。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?