OpenSSL测试-SM3

任务详情

  1. 在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务
  2. 使用OpenSSL的命令计算你的8位学号的摘要值(SM3),提交截图(5’)
  3. 使用OpenSSL编程对计算”你的8位学号”SM3摘要值,提交代码和运行结果截图。(10’)
  4. 使用OpenSSL编程对计算内容为”所有同学的8位学号”的文件的SM3摘要值,提交代码和运行结果截图。(选做(10’))

任务过程

1.openssl命令使用sm3计算学号摘要

 OpenSSL测试-SM3
  1. 计算sm3摘要编程实现
    代码:
#include <stdio.h>
#include <string.h>
#include <openssl evp.h>
void tDigest()
{
    unsigned char sm3_value[EVP_MAX_MD_SIZE];   //&#x4FDD;&#x5B58;&#x8F93;&#x51FA;&#x7684;&#x6458;&#x8981;&#x503C;&#x7684;&#x6570;&#x7EC4;
    int sm3_len, i;
    EVP_MD_CTX *sm3ctx;                         //EVP&#x6D88;&#x606F;&#x6458;&#x8981;&#x7ED3;&#x6784;&#x4F53;
    sm3ctx = EVP_MD_CTX_new();//&#x8C03;&#x7528;&#x51FD;&#x6570;&#x521D;&#x59CB;&#x5316;
    char msg1[] = "Test Message1";              //&#x5F85;&#x8BA1;&#x7B97;&#x6458;&#x8981;&#x7684;&#x6D88;&#x606F;1
    char msg2[] = "20191223";              //&#x5F85;&#x8BA1;&#x7B97;&#x6458;&#x8981;&#x7684;&#x6D88;&#x606F;2(&#x6211;&#x7684;&#x5B66;&#x53F7;&#xFF09;

    EVP_MD_CTX_init(sm3ctx);                    //&#x521D;&#x59CB;&#x5316;&#x6458;&#x8981;&#x7ED3;&#x6784;&#x4F53;
    EVP_DigestInit_ex(sm3ctx, EVP_sm3(), NULL); //&#x8BBE;&#x7F6E;&#x6458;&#x8981;&#x7B97;&#x6CD5;&#x548C;&#x5BC6;&#x7801;&#x7B97;&#x6CD5;&#x5F15;&#x64CE;&#xFF0C;&#x8FD9;&#x91CC;&#x5BC6;&#x7801;&#x7B97;&#x6CD5;&#x4F7F;&#x7528;sm3&#xFF0C;&#x7B97;&#x6CD5;&#x5F15;&#x64CE;&#x4F7F;&#x7528;OpenSSL&#x9ED8;&#x8BA4;&#x5F15;&#x64CE;&#x5373;&#x8F6F;&#x7B97;&#x6CD5;
    EVP_DigestUpdate(sm3ctx, msg1, strlen(msg1));//&#x8C03;&#x7528;&#x6458;&#x8981;UpDate&#x8BA1;&#x7B97;msg1&#x7684;&#x6458;&#x8981;
    EVP_DigestUpdate(sm3ctx, msg2, strlen(msg2));//&#x8C03;&#x7528;&#x6458;&#x8981;UpDate&#x8BA1;&#x7B97;msg2&#x7684;&#x6458;&#x8981;
    EVP_DigestFinal_ex(sm3ctx, sm3_value, &sm3_len);//&#x6458;&#x8981;&#x7ED3;&#x675F;&#xFF0C;&#x8F93;&#x51FA;&#x6458;&#x8981;&#x503C;
    EVP_MD_CTX_reset(sm3ctx);                       //&#x91CA;&#x653E;&#x5185;&#x5B58;

    printf("&#x539F;&#x59CB;&#x6570;&#x636E;%s&#x548C;%s&#x7684;&#x6458;&#x8981;&#x503C;&#x4E3A;:\n",msg1,msg2);
    for(i = 0; i < sm3_len; i++)
    {
        printf("0x%02x ", sm3_value[i]);
    }
    printf("\n");
}
int main()
{
    OpenSSL_add_all_algorithms();
    tDigest();
    return 0;
}
</openssl></string.h></stdio.h>

 OpenSSL测试-SM3
  1. 使用OpenSSL编程对计算内容为”所有同学的8位学号”的文件的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;
        sm3ctx = EVP_MD_CTX_new();
        char msg1[10000] = "";
        FILE *file;
        char line[32];
        char *ret;
        file = fopen("sno.txt", "r");
        if (!file) {
                printf("&#x6587;&#x4EF6;&#x6253;&#x5F00;&#x5931;&#x8D25;!\n");
                return 1;
        }
        while (ret = fgets(line, sizeof(line), file)) {
                strcat(msg1,line);
        }        printf("sno.txt&#x4E2D;&#x7684;&#x5185;&#x5BB9;&#x4E3A;\n%s\n",msg1);
        fclose(file);
        EVP_MD_CTX_init(sm3ctx);
        EVP_DigestInit_ex(sm3ctx, EVP_sm3(), NULL);
        EVP_DigestUpdate(sm3ctx, msg1, strlen(msg1));
        EVP_DigestFinal_ex(sm3ctx, sm3_value, &sm3_len);
        EVP_MD_CTX_reset(sm3ctx);
        printf("sno.txt&#x7684;&#x6458;&#x8981;&#x503C;&#x4E3A;:\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;
}
</openssl></string.h></stdio.h>

编译指令是 gcc sm3.c -o sm3 -lcrypto

 OpenSSL测试-SM3

Original: https://www.cnblogs.com/zzjjyy123/p/16144749.html
Author: 20191223张俊怡
Title: OpenSSL测试-SM3

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/585845/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • apparmor 源码分析

    这里不对apparmor做介绍,记录一下源码分析过程。 static int __init apparmor_init(void) -> security_add_hooks…

    Linux 2023年6月13日
    075
  • 【git】git将本地代码上传远程仓库

    环境要求: windows平台可以直接下载安装git.exe(安装选中加入),右键文件使用git bash按以下命令输入 Ubuntu平台下执行sudo apt install g…

    Linux 2023年6月13日
    0113
  • Centos7安装Redis

    下载 wget http://download.redis.io/releases/redis-5.0.0.tar.gz 解压 tar xvf redis-5.0.0.tar.gz…

    Linux 2023年5月28日
    095
  • Jenkins初始化界面一直显示Please wait while Jenkins is getting ready to work …

    第一次访问 jenkins时,会提示如下界面: 注:如果这个界面初始化的时间过长,则需要修改相关配置文件。 原因:因为访问官网太慢。我们只需要换一个源,不使用官网的源即可。 1、找…

    Linux 2023年6月13日
    099
  • grafana+prometheus如何查看tcp连接数量

    最后解决方案 经过和负责监控的大佬了解,获得了一个可行的方案:在每个pod中新增一个sidecar容器,在容器中部署node_exporter,或者在容器中放个自动查看端口连接数并…

    Linux 2023年6月13日
    0107
  • bash 教程-4 shell 脚本 调试 环境 [MD]

    我的GitHub 我的博客 我的微信 我的邮箱 bqt20094 baiqiantao@sina.com 脚本基础 脚本 script 就是包含一系列命令的一个文本文件,所有能够在…

    Linux 2023年5月28日
    092
  • 作业一、安装Ubuntu系统

    Ubuntu1804安装 一、安装环境 1、VMware Workstation 16 Pro 2、Ubuntu 18.04.6 LTS 二、部署系统 步骤1、进入VMware,点…

    Linux 2023年6月13日
    086
  • make

    make 背景 gcc 在编译一个包含多个源文件的工程时, gcc需要将每一个源文件都编译一遍,任何再链接起来形成一个可执行文件。实际上,用户很少对所有源文件都进行修改,这就会造成…

    Linux 2023年6月7日
    0104
  • 用 shell 脚本做命令行工具扩展

    问题的提出 公司开发机与远程服务器之间有严格的隔离策略,不能直接使用 ssh 登录,而必需通过跳板机。这样一来,本地与服务器之间的一些文件传输变得非常不便。经过咨询,运维教了我一招…

    Linux 2023年5月27日
    0124
  • postgres 错误duplicate key value violates unique constraint 解决方案

    把当前最大的id做为当前的id自增起始数运行下面的SQL就行了 SELECT setval(‘tablename_id_seq’, (SELECT MAX(id) FROM tab…

    Linux 2023年6月14日
    0105
  • Spring 进入Controller前参数校验

    在进入Controller前完成参数的校验,针对对象参数 分为两个验证方式 (1)直接使用已定义的校验方式 1、在需要进行校验的属性上增加校验类型注解 import java.ut…

    Linux 2023年6月7日
    0128
  • openstack 安装neutron网络服务安装 报错:Unknown operation ‘enabled’

    注:这个脚本文件有一个地方是错误的,最后一行需要修改一下 vim /usr/local/bin/iass-install-neutron-controller-gre.sh 改sy…

    Linux 2023年6月13日
    0201
  • mac 如何仅安装redis-cli客户端

    brew tap ringohub/redis-cli brew update && brew doctor brew install redis-cli 【注】需…

    Linux 2023年5月28日
    0120
  • Python的偏函数(Partial Function Application)

    这个概念说实话以前听过,但没深究过,也没用到过…但是被人问到了,就查来记录一下。 查下资料,发现这个东西说白了就是:部分参数有默认值的函数,Orz。再回过头来看他的英文…

    Linux 2023年6月8日
    097
  • SSO之CAS

    单点登录SSO ​ 单点登录的主要原理就是在每次登录成功以后生成一个唯一不可重复的令牌 token,我们就简单的用了一个随 机的 UUID 来生成 token。当用户登录成功后用生…

    Linux 2023年6月7日
    079
  • 2021年3月-第02阶段-前端基础-HTML+CSS阶段-Day03

    HTML5 第三天 一、 认识 3D 转换 3D 的特点 近大远小 物体和面遮挡不可见 三维坐标系 x 轴:水平向右 — 注意:x 轴右边是正值,左边是负值 y 轴:垂…

    Linux 2023年6月8日
    0113
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球