OpenSSL/GMSSL EVP接口说明——2.8 MAC示例代码

这段代码演示了如何在C语言中使用OpenSSL库执行HMAC-SM3散列函数,对给定的消息进行签名和验证。它初始化HMAC上下文,设置密钥,更新消息并比较两个生成的摘要以检查一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2.8 MAC示例代码

#include "openssl/hmac.h"

int test_evp_hmac_sm3()

{

        const EVP_MD *md = NULL;

        int flag, dlen1, dlen2;

        unsigned char key[16]={0x66,0xc7,0xf0,0xf4, 0x62,0xee,0xed,0xd9, 0xd1,0xf2,0xd4,0x6b, 0xdc,0x10,0xe4,0xe2};

        unsigned char msg[64]={      

                 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 

                 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64,

                 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64,

                 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64, 0x61,0x62,0x63,0x64   

        };

        unsigned char digest1[64],digest2[64], *pdata = NULL;

        HMAC_CTX ctx, ctx2;

printf("\n************************************************************\n");

        printf("测试OpenSSL HMAC SM3\n\n");

        md = EVP_sm3();

        HMAC_CTX_init(&ctx);

        flag = HMAC_Init(&ctx, key, sizeof(key), md);  

        flag = HMAC_Update(&ctx, msg, sizeof(msg));

        flag = HMAC_Final(&ctx, digest1, &dlen1);

        HMAC_CTX_cleanup(&ctx);

        pdata = HMAC( md, key, sizeof(key), msg, sizeof(msg), digest2, &dlen2);

        flag = ( memcmp(digest1, digest2, dlen1) == 0 );

        printf("flag = %d\n\n", flag);

        return 1;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值