使用 openssl 进行哈希计算

news/2024/4/25 18:18:41

版本:OpenSSL 3.0.2 15 Mar 2022 (Library: OpenSSL 3.0.2 15 Mar 2022)

SHAx 系列

如果对象完全存储在内存中,可以使用以下函数:

#include <openssl/sha.h>unsigned char *SHA1(const unsigned char *data, size_t count, unsigned char *md_buf);
unsigned char *SHA224(const unsigned char *data, size_t count, unsigned char *md_buf);
unsigned char *SHA256(const unsigned char *data, size_t count, unsigned char *md_buf);
unsigned char *SHA384(const unsigned char *data, size_t count, unsigned char *md_buf);
unsigned char *SHA512(const unsigned char *data, size_t count, unsigned char *md_buf);

使用示例:

int i = 0;
const char *data = "Hello World";
unsigned char sha1[SHA_DIGEST_LENGTH];SHA1(data, strlen(data), sha1);printf("%s sha1 = ", data);
for (i = 0; i < SHA_DIGEST_LENGTH; i++) {printf("%02x", sha1[i]);
}

SHAx_Init 系列

如果对象未完全存储在内存中,可以使用以下函数(注意:以下函数已经在 3.0 版本中废弃):

int SHA1_Init(SHA_CTX *c);
int SHA1_Update(SHA_CTX *c, const void *data, size_t len);
int SHA1_Final(unsigned char *md, SHA_CTX *c);int SHA224_Init(SHA256_CTX *c);
int SHA224_Update(SHA256_CTX *c, const void *data, size_t len);
int SHA224_Final(unsigned char *md, SHA256_CTX *c);int SHA256_Init(SHA256_CTX *c);
int SHA256_Update(SHA256_CTX *c, const void *data, size_t len);
int SHA256_Final(unsigned char *md, SHA256_CTX *c);int SHA384_Init(SHA512_CTX *c);
int SHA384_Update(SHA512_CTX *c, const void *data, size_t len);
int SHA384_Final(unsigned char *md, SHA512_CTX *c);int SHA512_Init(SHA512_CTX *c);
int SHA512_Update(SHA512_CTX *c, const void *data, size_t len);
int SHA512_Final(unsigned char *md, SHA512_CTX *c);

使用示例:


#define OPENSSL_API_COMPAT 0x10100000L /* 在 >= 3.0 版本中需要定义该宏才能使用 SHAx_Init 系列函数,该宏详情见 https://www.openssl.org/docs/man3.2/man7/openssl_user_macros.html */SHA_CTX c;
int i = 0;
const char *data = "Hello World";
unsigned char sha1[SHA_DIGEST_LENGTH];SHA1_Init(&c);
SHA1_Update(&c, data, strlen(data));
SHA1_Final(sha1, &c);printf("%s sha1 = ", data);
for (i = 0; i < SHA_DIGEST_LENGTH; i++) {printf("%02x", sha1[i]);
}

 

#define OPENSSL_API_COMPAT 0x10100000L /* 在 >= 3.0 版本中需要定义该宏才能使用 SHAx_Init 系列函数,该宏详情见 https://www.openssl.org/docs/man3.2/man7/openssl_user_macros.html */int sha1_file(char *file)
{
#define READ_SIZE 128if (!file)return 0;int i = 0;int n = 0;SHA_CTX c;FILE *fp = NULL;unsigned char temp[READ_SIZE];unsigned char sha1[SHA_DIGEST_LENGTH];fp = fopen(file, "r");if (!fp)return -1;SHA1_Init(&c);do{memset(temp, 0, sizeof(temp));n = fread(temp, 1, READ_SIZE, fp);if (n > 0)SHA1_Update(&c, temp, n);} while (n > 0);SHA1_Final(sha1, &c);printf("file [%s] sha1 = ", file);for (i = 0; i < SHA_DIGEST_LENGTH; i++){printf("%02x", sha1[i]);}fclose(fp);return 0;
}

3.0 版本

3.0 版本推荐使用用 EVP_DigestInit_ex(3), EVP_DigestUpdate(3) , EVP_DigestFinal_ex(3)

使用示例:

int i = 0;
EVP_MD_CTX *ctx = NULL;
const char *data = "Hello World";
unsigned char sha1[SHA_DIGEST_LENGTH];ctx = EVP_MD_CTX_new();
EVP_DigestInit_ex(ctx, EVP_sha1(), NULL);
EVP_DigestUpdate(ctx, data, strlen(data));
EVP_DigestFinal_ex(ctx, sha1, NULL);
EVP_MD_CTX_free(ctx);printf("%s sha1 = ", data);
for (i = 0; i < SHA_DIGEST_LENGTH; i++)
{printf("%02x", sha1[i]);
}

快速哈希功能

EVP_Q_digest(3)

int EVP_Q_digest(OSSL_LIB_CTX *libctx, const char *name, const char *propq,const void *data, size_t datalen,unsigned char *md, size_t *mdlen);

 使用示例:

const char *data = "Hello World";
unsigned char sha1[SHA_DIGEST_LENGTH];EVP_Q_digest(NULL, "SHA1", NULL, data, strlen(data), sha1, NULL)


https://www.xjx100.cn/news/3280864.html

相关文章

VSCode-下载安装-远程连接linux(方便容器编排格式学习)

VSCode下载安装 下载安装请参考 VSCode下载教程https://blog.csdn.net/weixin_43121885/article/details/131779104?ops_request_misc%257B%2522request%255Fid%2522%253A%2522170812811316800211530507%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&am…

open3d 0.17.0的open3d.visualization.ViewControl类有bug

1. 问题描述 在使用过程中发现open3d.visualization.ViewControl的如下方法&#xff0c;在open3d 0.17.0环境下不起作用&#xff0c;点云的显示视场还是默认配置&#xff1b;而在open3d 0.16.0环境下却正常工作。 rotateset_frontset_lookatset_upset_zoom 2. 测试代码 imp…

前端秘法基础式终章----欢迎来到JS的世界

目录 一.JavaScript的背景 二.JavaScript的书写形式 1.行内式 2.嵌入式 3.外部式 三.JS中的变量 1.变量的定义 2.JS动态类型变量 2.1强类型和弱类型 3.JS中的变量类型 四.运算符 五.if语句和三元表达式和Switch语句和循环语句 六.数组 1.创建获取数组元素 2.新增…

消息队列-RabbitMQ:发布确认—发布确认逻辑和发布确认的策略

九、发布确认 1、发布确认逻辑 生产者将信道设置成 confirm 模式&#xff0c;一旦信道进入 confirm 模式&#xff0c;所有在该信道上面发布的消息都将会被指派一个唯一的 ID (从 1 开始)&#xff0c;一旦消息被投递到所有匹配的队列之后&#xff0c;broker 就会发送一个确认给…

python 与 neo4j 交互(py2neo 使用)

参考自&#xff1a;neo4j的python.py2neo操作入门 官方文档&#xff1a;The Py2neo Handbook — py2neo 2021.1 安装&#xff1a;pip install py2neo -i https://pypi.tuna.tsinghua.edu.cn/simple 1 节点 / 关系 / 属性 / 路径 节点(Node)和关系(relationship)是构成图的基础…

HTTPS(超文本传输安全协议)被恶意请求该如何处理。

HTTPS&#xff08;超文本传输安全协议&#xff09;端口攻击通常是指SSL握手中的一些攻击方式&#xff0c;比如SSL握手协商过程中的暴力破解、中间人攻击和SSL剥离攻击等。 攻击原理 攻击者控制受害者发送大量请求&#xff0c;利用压缩算法的机制猜测请求中的关键信息&#xf…

编程笔记 Golang基础 008 基本语法规则

编程笔记 Golang基础 008 基本语法规则 Go语言的基本语法规则. Go语言的基本语法规则包括但不限于以下要点&#xff1a; 标识符&#xff1a; 标识符用于命名变量、常量、类型、函数、包等。标识符由字母&#xff08;a-z&#xff0c;A-Z&#xff09;、数字&#xff08;0-9&#…

Spring Cloud Alibaba-04-Sentinel服务容错

Lison <dreamlison163.com>, v1.0.0, 2023.09.10 Spring Cloud Alibaba-04-Sentinel服务容错 文章目录 Spring Cloud Alibaba-04-Sentinel服务容错高并发带来的问题服务雪崩效应常见容错方案Sentinel入门什么是Sentinel微服务集成Sentinel安装Sentinel控制台 实现一个接…