首页 > 其他分享 >OpenSSL测试-SM3

OpenSSL测试-SM3

时间:2023-04-12 09:00:39浏览次数:36  
标签:sm3ctx SM3 摘要 sm3 OpenSSL 测试 EVP msg1

OpenSSL测试-SM3
任务详情

  1. 在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务
  2. 使用OpenSSL的命令计算你的8位学号的摘要值(SM3),提交截图(5')
  3. 使用OpenSSL编程对计算"你的8位学号"SM3摘要值,提交代码和运行结果截图。(10’)
  4. 使用OpenSSL编程对计算内容为"所有同学的8位学号"的文件的SM3摘要值,提交代码和运行结果截图。(选做(10’))
    使用OpenSSL的命令计算你的8位学号的摘要值(SM3)
    使用命令echo -n "20201205" | openssl dgst -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[] = "Test Message1";              //待计算摘要的消息1
    char msg2[] = "20201212";              //待计算摘要的消息2(我的学号)
     
    EVP_MD_CTX_init(sm3ctx);                    //初始化摘要结构体
    EVP_DigestInit_ex(sm3ctx, EVP_sm3(), NULL); //设置摘要算法和密码算法引擎,这里密码算法使用sm3,算法引擎使用OpenSSL默认引擎即软算法
    EVP_DigestUpdate(sm3ctx, msg1, strlen(msg1));//调用摘要UpDate计算msg1的摘要
    EVP_DigestUpdate(sm3ctx, msg2, strlen(msg2));//调用摘要UpDate计算msg2的摘要 
    EVP_DigestFinal_ex(sm3ctx, sm3_value, &sm3_len);//摘要结束,输出摘要值   
    EVP_MD_CTX_reset(sm3ctx);                       //释放内存
     
    printf("原始数据%s和%s的摘要值为:\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编程对计算"你的8位学号"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("id.txt", "r");
        if (!file) {
                printf("文件打开失败!\n");
                return 1;
        }
        while (ret = fgets(line, sizeof(line), file)) {
                strcat(msg1,line);
        }        printf("id.txt中的内容为\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("id.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;
}

标签:sm3ctx,SM3,摘要,sm3,OpenSSL,测试,EVP,msg1
From: https://www.cnblogs.com/gtgtgt/p/17308571.html

相关文章

  • OpenSSL测试-随机数
    任务详情在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务使用OpenSSL定义一个私有函数staticintgetRandom(char*r,intlength),获取length个字节的随机数(5‘)把上述函数集成到src中的sdf.c中的SDF_GenerateRandom中(5')在test中的main.c调用SDF_GenerateRandom......
  • OpenSSL测试-大数
    任务详情在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务基于OpenSSL的大数库计算2的N次方,N为你学号的后四位(5‘)基于OpenSSL的大数库计算你以及前面5位同学和后面5位同学的8位学号的乘积,N为你学号的后四位(5‘)用Python或bc命令验证计算的正确性(5’)提交代码(或代码链......
  • 使用RunnerGo做接口性能、接口自动化测试
    最近在gitee上看见一款获得GVP(最有价值开源项目)的测试平台RunnerGo,看他们官网介绍包含了接口测试、性能测试、自动化测试。知道他们有saas版可以试用,果断使用了一下,对其中场景管理和性能测试印象深刻,之后也在公司自己安装使用,接下来和大家介绍一下RunnerGo的整体使用情况。登录后的......
  • 软件测试综合面试题
    项目中会对接第三方系统吗,哪些系统在项目中对接第三方系统是非常常见的。常见的对接的第三方系统包括但不限于以下几种:1.支付系统:例如支付宝、微信支付、银联支付等。如果项目需要接入支付功能,就需要对接相应的支付系统。2.物流系统:例如顺丰、圆通、中通等。如果项目中需要使......
  • 安全测试前置实践1-白盒&黑盒扫描
    作者:京东物流 陈维一、引言G.J.Myers在《软件测试的艺术》中提出:从心理学角度来说,测试是一个为了寻找错误而运行程序的过程。那么安全测试则是一个寻找系统潜在安全问题的过程,通过测试手段发现系统中可能存在的安全问题和风险,分析并进行优化,保障系统的安全质量。从应用安全维......
  • 【性能测试】04测试分析及调优
    本文通过编写性能测试分析及调优的相关流程和方法,帮助研发人员、性能测试人员或者运维人员快速地进行性能测试、瓶颈定位及调优。系统的性能是由很多因素决定的,很难面面俱到,但是可以作为分析系统性能的一个指导。适用对象和范围适用于需要进行性能分析及调优的工作。预期读者......
  • ASN.1 基础测试
    1参考https://www.cnblogs.com/rocedu/p/14891816.html#echo打印字符串和变量值2十六进制数:30030201AA,写入文件1.der,用od查看内容,用asn1view或opensslasn1pars命令查看内容,提交截图3十六进制数:3013020105160e416e79626f64792074686572653f,写......
  • 北上广测试工程师月薪20K往上,该如何做,需要会什么技能?
    ​有人回答说这只能是大企业或者互联网企业工程师才能拿到。也许是的,小公司或者非互联网企业拿两万的不太可能是码农了,应该已经转管理。还有区域问题,这个不在我的考虑范围内,因为除了北上广深杭,其他地方也很难达到。 还有人提到这个水平不止2w,其实工资是跟面试表现有关的,也跟......
  • OpenSSL测试-大数
    在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务基于OpenSSL的大数库计算2的N次方,N为你学号的后四位(5‘)基于OpenSSL的大数库计算你以及前面5位同学和后面5位同学的8位学号的乘积,N为你学号的后四位(5‘)用Python或bc命令验证计算的正确性(5’)提交代码(或代码链接)和运行......
  • 2023.04.11 定时测试随笔 T1
    T1数列分段SectionII传送门:洛谷P1182题意:把\(n\)个数分成\(m\)段,使\(m\)段和的最大值最小,求这个值;题解:因为题目要求最大值的最小值,很明显的一道二分答案的板子题,我们二分这个最大值,因为是区间和,我们用前缀和来维护,二分区间就是[\(sum[1]\),\(sum[n]\)]:......