Как извлечь несжатый открытый ключ из secp256k1?

РЕДАКТИРОВАТЬ: Вопрос сильно отредактирован, чтобы сузить фокус вопроса

Я пытаюсь извлечь несжатый открытый ключ из структуры secp256k1::key::PublicKey.

В зависимости от того, какое форматирование печати я использую, я получаю сжатый или несжатый ключ.

Как видно из этого вопроса, несжатый ключ является шестнадцатеричным (или байтовым) обратным (вы можете видеть, что обратная сторона сжатой версии - это начало несжатой версии).

Я не знаю, как извлечь из структуры 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, 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]


person Isambard_FA    schedule 26.02.2021    source источник
comment
uncompressed_public_key тоже хорошо или это уже плохо, или вы не знаете?   -  person Hadus    schedule 27.02.2021
comment
Я не знаю, так как его нет на сайте, с которым я сравниваю. Однако я подозреваю, что преобразование сжатого открытого ключа в несжатый открытый ключ неверно. С признаком отображения println!("Compressed Public Key: {}", ex_pub_key.public_key.key); дает 33-байтовый вывод, а использование {:?} дает 64-байтовый вывод. Однако последние 32 байта сжатого ключа должны быть частью 64-байтового ключа, и это, похоже, не так ...   -  person Isambard_FA    schedule 27.02.2021
comment
РЕДАКТИРОВАТЬ: После еще нескольких исследований я теперь почти уверен, что моя проблема заключается в создании несжатого открытого ключа. Кто-нибудь знает, когда предоставляется сжатый ключ, как сгенерировать несжатый ключ?   -  person Isambard_FA    schedule 01.03.2021


Ответы (1)


После долгих исследований я обнаружил, что есть простой способ извлечь несжатый открытый ключ, используя метод serialize_uncompressed() для открытого ключа, который является частью того же secp256k1 ящика.

Это обеспечивает 65-байтовый вывод, из которого следует отбросить первый байт, чтобы создать правильный 64-байтовый открытый ключ.

person Isambard_FA    schedule 11.03.2021
comment
Это также в правильном порядке, в отличие от печати открытого ключа с признаком отображения. - person Isambard_FA; 15.03.2021