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;

}

<think>好的,我现在遇到了一个编译错误:“openssl/evp.h: No suchfile or directory”。这个问题看起来是在编译过程中找不到OpenSSL的头文件。我需要先确认用户是在什么环境下遇到这个问题的。通常这种情况发生在尝试编译依赖OpenSSL的C/C++项目时,但系统没有安装OpenSSL的开发库。 首先,我应该考虑不同的操作系统解决方案。对于基于Debian/Ubuntu的系统,用户可能需要安装libssl-dev包,这个包提供了OpenSSL的头文件和库。安装命令是sudoapt-get install libssl-dev。如果是Fedora/CentOS系统,对应的包可能是openssl-devel,使用dnf或者yum来安装。接下来,用户可能已经安装了开发库,但编译时仍然找不到头文件。这时候需要检查编译命令是否正确包含了头文件路径。例如,使用gcc编译时,应该通过-I选项指定头文件的位置,比如gcc -I/usr/include/openssl ...,不过通常安装开发库后,头文件会放在标准路径,不需要特别指定。 如果用户是在非标准位置安装了OpenSSL,可能需要显式地指定头文件和库文件的路径。这时候编译命令需要包含-I/path/to/openssl/include和-L/path/to/openssl/lib,并在链接时添加-lssl -lcrypto。 另外,确认OpenSSL是否正确安装也很重要。用户可以通过命令如openssl version查看是否安装了OpenSSL运行时库,而开发库可能需要单独安装。如果问题依旧,可能需要检查文件系统是否存在evp.h,比如使用find /-name evp.h 2>/dev/null来查找文件位置,然后确保编译命令正确引用了该路径。 最后,如果用户使用CMake,需要在CMakeLists.txt中正确找到OpenSSL库,比如使用find_package(OpenSSL REQUIRED)并包含相关目录和链接库。总结起来,解决步骤包括安装开发库、检查安装路径、调整编译命令参数等。需要根据具体情况提供相应的解决方案。</think>当出现`openssl/evp.h: No such file or directory`错误时,表示编译时找不到OpenSSL的开发头文件。以下是不同场景下的解决方案: 1. **Ubuntu/Debian系统**: ```bash # 安装OpenSSL开发包 sudo apt-get update && sudo apt-get install libssl-dev ``` 2. **Fedora/CentOS系统**: ```bash # 安装OpenSSL开发包 sudo dnf install openssl-devel # Fedora # 或 sudo yum install openssl-devel # CentOS ``` 3. **编译时指定路径**(适用于自定义安装路径): ```bash # 假设OpenSSL安装在/opt/openssl gcc -I/opt/openssl/include -L/opt/openssl/lib -lssl -lcrypto your_program.c ``` 4. **验证安装**: ```bash # 检查头文件是否存在 ls /usr/include/openssl/evp.h # 标准路径 # 检查开发包是否安装 dpkg -l libssl-dev # Debian/Ubuntu rpm -q openssl-devel # RHEL/CentOS ``` 5. **CMake项目配置**: ```cmake cmake_minimum_required(VERSION 3.10) project(YourProject) find_package(OpenSSL REQUIRED) include_directories(${OPENSSL_INCLUDE_DIR}) add_executable(your_program your_program.c) target_link_libraries(your_program OpenSSL::SSL OpenSSL::Crypto) ``` **原理解释**: - 该错误表示编译器在标准包含路径中找不到OpenSSLEVP加密接口头文件 - OpenSSL开发包包含头文件(.h)和库文件(.so/.a),需要单独安装 - 不同Linux发行版的开发包命名不同(libssl-dev vs openssl-devel)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值