OpenSSL测试-SM3
1.使用OpenSSL的命令计算你的8位学号的摘要值(SM3),提交截图。
运行结果
2.使用OpenSSL编程对计算"你的8位学号"SM3摘要值,提交代码和运行结果截图。
使用代码
代码链接:https://gitee.com/amyonelse/research-on-exp1-api.git
3. 使用OpenSSL编程对计算内容为"所有同学的8位学号"的文件的SM3摘要值,提交代码和运行结果截图。
运行结果:
代码如下:
//计算所有同学的八位学号的sm3摘要值 #include <stdio.h> #include <string.h> #include <openssl/evp.h> void tDigest() { unsigned char sm3_value[EVP_MAX_MD_SIZE]; //保存输出的摘要值的数组 int sm3_len, i; EVP_MD_CTX *sm3ctx; //EVP消息摘要结构体 sm3ctx = EVP_MD_CTX_new(); char msg1[10000] = ""; //待计算摘要的消息1 FILE *file; char line[32]; char *ret; file = fopen("20181217.txt", "r"); // 打开文件 if (!file) { // 判断文件是否打开失败 printf("文件打开失败!\n"); return 1; } /* while (1) { ret = fgets(line, sizeof(line), file); if (!ret) { break; } printf("%s", line); } */ while (ret = fgets(line, sizeof(line), file)) { // 从文件中读取一行并 //printf("%s", line); strcat(msg1,line); //printf("hello!!!chenchen"); // line就是读取到的一行字符串,根据自己的需要进行操作字符串即可 } printf("20181217.txt中的内容为\n%s\n",msg1); fclose(file); EVP_MD_CTX_init(sm3ctx); //初始化摘要结构体 EVP_DigestInit_ex(sm3ctx, EVP_sm3(), NULL); //设置摘要算法和密码算法引擎,这里密码算法使用MD5,算法引擎使用OpenSSL默认引擎即软算法 EVP_DigestUpdate(sm3ctx, msg1, strlen(msg1));//调用摘要UpDate计算msg1的摘要 EVP_DigestFinal_ex(sm3ctx, sm3_value, &sm3_len);//摘要结束,输出摘要值 EVP_MD_CTX_reset(sm3ctx); //释放内存 printf("原始文件20181217.txt的摘要值为:\n"); for(i = 0; i < sm3_len; i++) { printf("0x%02x ", sm3_value[i]); } printf("\n"); } int main() { OpenSSL_add_all_algorithms(); tDigest(); return 0; }