0

我编写的代码以某种方式无法正常工作。当通过在线工具使用相同的密钥和密码时,hmac 是不同的。

我的代码是:

    EVP_MD_CTX* mdctx = NULL;
    const EVP_MD* md = NULL;
    EVP_PKEY *pkey = NULL;
    
    unsigned char md_value[EVP_MAX_MD_SIZE];
    size_t md_len = 0;

    mdctx = EVP_MD_CTX_create();
    md = EVP_get_digestbyname("SHA256");
    const unsigned char  a[] = "qwertzuiopqwertzuiopqw";
    pkey = EVP_PKEY_new_mac_key(EVP_PKEY_HMAC, NULL, a, strlen("qwertzuiopqwertzuiopqw"));
    EVP_DigestSignInit(mdctx, NULL, md, NULL, pkey);
   EVP_DigestSignUpdate(mdctx, "Hallo", sizeof("Hallo")); // iv
    EVP_DigestSignFinal(mdctx, md_value, &md_len);

我的代码计算出来的hmac是:eadfb51c9fb3f3fcd5741006861d04bc0d695347db4bfb9e04e954e17583c3c5。

online-tool计算的hmac为:a9e0f9acc1452bdb796556c3c64e29d7f7ab47a59a179ec918c61894eefeba26。

我究竟做错了什么?

4

0 回答 0