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)

大家都在看

  • PHP实现无限级分类

    $array = array( array(‘id’ => 1, ‘pid’ => 0, ‘name’ => ‘河北省’), array(‘id’ => 2…

    Linux 2023年6月7日
    068
  • Mysql数据库体系

    Mysql数据库体系如下(手绘): 描述: 1.DBMS:database system management是数据库管理软件,平时我们使用的数据库的全称,是C/S架构(clien…

    Linux 2023年6月14日
    0106
  • ThinkPHP5 远程命令执行漏洞

    一、ThinkPHP介绍 轻量级框架,内部OOP和面向过程代码都存在,是国人自己开发的框架。ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,诞生于2006年初,…

    Linux 2023年6月14日
    079
  • 数据库性能优化八大方案,你知道几个

    前言 毫不夸张的说咱们后端工程师,无论在哪家公司,呆在哪个团队,做哪个系统,遇到的第一个让人头疼的问题绝对是数据库性能问题。 如果我们有一套成熟的方法论,能让大家快速、准确的去选择…

    Linux 2023年6月13日
    074
  • 高级IPC DBus

    404. 抱歉,您访问的资源不存在。 可能是URL不正确,或者对应的内容已经被删除,或者处于隐私状态。 [En] It may be that the URL is incorre…

    Linux 2023年5月27日
    0108
  • 关于如何在window下执行SQLSERVER的定时备份

    引言 在使用SqlServer Express 版本的时候发现,这个版本不支持通过数据库的代理方式进行数据库的维护。 解决方案 使用SQL语句加windows任务计划的方式解决具体…

    Linux 2023年6月14日
    098
  • 剪贴板被占用导致应用使用剪贴板拷贝内容失败抛出 COMException 0x800401D0 错误

    本文记录某些软件,例如 向日葵远程控制 软件占用剪贴板,导致 WPF 应用使用剪贴板拷贝内容和设置剪贴板时,抛出 System.Runtime.InteropServices.CO…

    Linux 2023年6月6日
    0134
  • Centos 7 上安装 jdk 及问题小记

    yum 下载安装 使用 yum -y list jav 或者 yum search jdk 查找 java 相关安装包的列表 yum -y list &#x641C;&am…

    Linux 2023年5月27日
    0111
  • 【网络安全篇】常见的HTTP状态码小结(3位5类)

    HTTP 状态码(HTTP Status Code)用以表示网页服务器传输协议的响应状态;状态码为 三位数,响应分为 五种;状态码的第1位数字表示状态类型,第2、3位数字表示具体的…

    Linux 2023年6月13日
    092
  • 1. 文件与I/O

    内核是如何处理系统调用 每个系统调用被赋予了一个系统调用号 在i386平台上,执行一个系统调用是通过int 0X80指令完成的 eax存放系统的调用号 ebx,ecx,edx,es…

    Linux 2023年6月6日
    090
  • 了解GFS

    参考: https://wenku.baidu.com/view/4392293517791711cc7931b765ce0508763275f2.html 论文翻译 https:…

    Linux 2023年6月7日
    0111
  • VirtualBox 和宿主机挂载共享文件夹 步骤记录

    问题记录 这个功能不常用(感觉这个步骤很繁琐,用finalshell连ssh就能很溜),但是有时候在公司网络受限的时候安装不了ssh,只能用这个挂载的方式。 防止后期遗忘步骤,我把…

    Linux 2023年6月6日
    0165
  • 万字长文入门 Redis 命令、事务、锁、订阅、性能测试

    作者:痴者工良 Redis 基本数据类型 Redis 的 Key Redis Key 命名 设置 Key 过期时间 判断键是否存在 搜索 Key 判断键类型 删除键 RESP 协议…

    Linux 2023年5月28日
    098
  • Java List和Map遍历的方法,forEach()的使用

    注意: 不要在foreach循环里进行元素的remove/add操作。remove元素请使用Iterator方式,如果并发操作,需要对Iterator对象加锁。 Java 8之前 …

    Linux 2023年6月7日
    0107
  • 我懂得了什么

    站在24岁的这个档口,没有学业又没有工作的时刻,前不着村后不着店。我觉得应该要写一些总结,虽然年仅24的我相比老人家总结不出更深刻的道理,但是现在是互联网的时代,获取知识的途径已经…

    Linux 2023年6月6日
    0104
  • 我为 Netty 贡献源码 | 且看 Netty 如何应对 TCP 连接的正常关闭,异常关闭,半关闭场景

    欢迎关注公众号:bin的技术小屋,本文图片加载不出来的话可查看公众号原文 本系列Netty源码解析文章基于 4.1.56.Final版本 写在前面….. 本文是笔者肉眼…

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