ZBLOG

EVP_DigestVerifyInit error: error:0300008E:digital envelope routines::expecting an ec key

这个错误是 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助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=10525

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?