这个错误是 OpenSSL 中的一个错误,表明在进行数字签名验证时,期望传入的密钥为 EC(椭圆曲线)密钥,但实际上传入的密钥不符合要求。
如果您遇到了这个错误,请确保在调用 EVP_DigestVerifyInit 函数之前正确设置了密钥参数,并且该密钥参数是一个有效的 EC 密钥。具体而言,您需要使用 EVP_PKEY_set1_EC_KEY 函数将 EC 密钥设置到 EVP_PKEY 结构中,并将该结构作为参数传递给 EVP_DigestVerifyInit 函数。
以下是示例代码:
#include <openssl/evp.h>
#include <openssl/ec.h>
int main() {
// 创建一个 EC 密钥
EC_KEY* ec_key = EC_KEY_new_by_curve_name(NID_secp256k1);
// 将 EC 密钥设置到 EVP_PKEY 结构中
EVP_PKEY* pkey = EVP_PKEY_new();
if (EVP_PKEY_set1_EC_KEY(pkey, ec_key) != 1) {
// 设置密钥失败
// 处理错误情况...
}
// 使用密钥进行数字签名验证
EVP_MD_CTX* ctx = EVP_MD_CTX_create();
if (EVP_DigestVerifyInit(ctx, NULL, EVP_sha256(), NULL, pkey) != 1) {
// 初始化验证上下文失败
// 处理错误情况...
}
// ...
// 最后记得释放资源
EVP_MD_CTX_destroy(ctx);
EVP_PKEY_free(pkey);
EC_KEY_free(ec_key);
return 0;
}
请注意,示例代码中只展示了设置 EC 密钥和初始化验证上下文的部分,您还需要根据具体情况添加其他必要的代码,如读取签名数据、提供待验证数据等。
如果问题仍然存在,请检查您传入的密钥是否正确,并确保所有 OpenSSL 相关的库和头文件正确安装并链接到您的项目中。
内容由零声教学AI助手提供,问题来源于学员提问




