用于设置ECC密钥mbedTLS的API

agxfikkp  于 2022-12-03  发布在  其他
关注(0)|答案(1)|浏览(304)

我尝试使用mbedTLS显式设置ECC私钥以进行ECDSA签名。该密钥是从mbedTLS外部生成的,由NIST secp256r1曲线中私钥和公钥的以下数组组成在我看到的所有mbedTLS ECDSA示例中,密钥是用随机数生成器mbedtls_ecp_gen_key()生成的,但这对我来说不起作用,因为我需要在代码外生成密钥对,然后在代码中显式设置。

const uint8_t Private_Key[] =
{
    0x0a, 0x75, 0xde, 0x36, 0x78, 0x73, 0x50, 0x8b, 0x25, 0x1e, 0x19, 0xbe, 0xf4, 0x7b, 0x74,
    0xfc, 0xd6, 0x97, 0x44, 0x12, 0x5f, 0x1c, 0x49, 0x89, 0x98, 0x0b, 0x65, 0x6c, 0x48, 0xa7, 0x8c, 0x5c

};

const uint8_t Public_Key[] =
{
    0x3b, 0x08, 0xd7, 0x1a, 0x1b, 0x5a, 0xd0, 0x3e, 0x41, 0x5d, 0x8f, 0x68, 0xe9, 0x78,0x47, 0x6b,
    0x35, 0x5c, 0xe2, 0x90, 0x8d, 0xb9, 0xc1, 0x46, 0xb1, 0x44, 0x77, 0x1f, 0x92, 0x57, 0xbf, 0x8e,
    0x7c, 0xed, 0xdf, 0x3b, 0xea, 0xed, 0x5d, 0xea, 0x1d, 0x77, 0x39, 0xdb, 0xb7, 0x42, 0xe3, 0x6a,
    0x07, 0x74, 0xca, 0x50, 0x8b, 0x19, 0xf5, 0x37, 0xd5, 0x2d, 0x57, 0x71, 0x70, 0x7e, 0xc7, 0x16
};
q9rjltbz

q9rjltbz1#

您可以查看mbedtls_ecp_read_key用于导入密钥,mbedtls_ecp_point_read_binary用于从外部生成的密钥数据导入公钥。请注意,mbedtls_ecp_point_read_binary需要未压缩公钥格式的二进制数据,即0x04后跟X后跟Y,这意味着您应该在代码中的Public_Key数据的头部添加0x04。

相关问题