1 在openEuler(推荐)或Ubuntu中,使用OpenSSL命令行工具,对消息“Hello, 你的姓名学号!”使用HMAC-SM3进行验证。密钥为随机数,自己生成。提交命令行操作过程截图和结果。
2 使用C语言和OpenSSL库,在openEuler或Ubuntu上编写程序对字符串“Hello, 你的姓名学号!”进行HMAC-SM3加密。密钥同上。提交完整代码和程序运行结果截图以及两次结果的对比。
#include <openssl/evp.h>
#include <openssl/hmac.h>
#include <openssl/rand.h>
#include <string.h>
#include <stdio.h>
void handleErrors(void) {
fprintf(stderr, "Error occurred\n");
exit(1);
}
void generate_random_key(unsigned char *key, int key_len) {
if (RAND_bytes(key, key_len) != 1) {
handleErrors();
}
}
void hmac_sm3(const unsigned char *key, int key_len,
const unsigned char *data, int data_len,
unsigned char *digest, unsigned int *digest_len) {
HMAC_CTX *ctx;
if (!(ctx = HMAC_CTX_new())) {
handleErrors();
}
if (HMAC_Init_ex(ctx, key, key_len, EVP_sm3(), NULL) != 1) {
HMAC_CTX_free(ctx);
handleErrors();
}
if (HMAC_Update(ctx, data, data_len) != 1) {
HMAC_CTX_free(ctx);
handleErrors();
}
if (HMAC_Final(ctx, digest, digest_len) != 1) {
HMAC_CTX_free(ctx);
handleErrors();
}
HMAC_CTX_free(ctx);
}
int main(void) {
unsigned char key[16]; // Adjust the size of key if needed
unsigned char data[] = "Hello, 20211106!";
unsigned char digest[EVP_MAX_MD_SIZE];
unsigned int digest_len;
generate_random_key(key, sizeof(key));
printf("Generated Key: ");
for (int i = 0; i < sizeof(key); ++i) {
printf("%02x", key[i]);
}
printf("\n");
hmac_sm3(key, sizeof(key), data, sizeof(data) - 1, digest, &digest_len);
printf("HMAC-SM3 Digest: ");
for (unsigned int i = 0; i < digest_len; ++i) {
printf("%02x", digest[i]);
}
printf("\n");
return 0;
}
gcc -o sm3 sm3.c -lssl -lcrypto
3 使用龙脉智能钥匙完成2的内容,提交完整代码和程序运行结果截图以及两次结果的对比。标签:测试,ctx,OpenSSL,len,unsigned,key,HMAC,digest From: https://www.cnblogs.com/sjd-sr/p/18165011