0

0

C++怎么使用SHA256_C++安全哈希教程【现代】

冰火之心

冰火之心

发布时间:2026-02-28 14:29:02

|

265人浏览过

|

来源于php中文网

原创

c++标准库不提供sha256实现,必须依赖openssl或libsodium等第三方库;openssl需手动管理上下文,libsodium支持单函数调用;输入须传准确长度,输出为32字节二进制,hex编码需手动实现。

c++怎么使用sha256_c++安全哈希教程【现代】

SHA256 在 C++ 里没有标准库实现

标准 C++(C++11/14/17/20/23)至今不提供 SHA256 或任何密码学哈希函数。别翻 <string></string><algorithm></algorithm><hash></hash>——它们全没用。你看到的所谓“C++ SHA256 教程”,实际都在调第三方库,不是语言原生能力。

常见误操作是直接搜 “C++ sha256 header”,结果引入非标准头文件(比如某些平台私有扩展),或误把 std::hash<:string></:string> 当成 SHA256(它只是快速但不安全的散列,碰撞多、不可逆、无固定长度)。

  • 别写 #include <sha256.h></sha256.h> —— 标准中不存在这个头
  • 别依赖编译器扩展(如 GCC 的 __builtin_sha256),它只在极少数 ARM 架构上存在,且非可移植
  • 别用 std::hash 替代:输出长度不定、不抗碰撞性、不满足 FIPS/PCI DSS 等合规要求

推荐用 OpenSSL(最稳)或 libsodium(最简)

生产环境首选 OpenSSL,因它被广泛审计、支持硬件加速、兼容 TLS/证书等生态;若只做简单哈希且想避免 OpenSSL 的复杂初始化和许可证顾虑,libsodium 更轻量(它把 crypto_hash_sha256 封装得像函数调用一样直白)。

二者关键差异:

立即学习C++免费学习笔记(深入)”;

摩笔天书
摩笔天书

摩笔天书AI绘本创作平台

下载
  • OpenSSL 需手动管理 EVP_MD_CTX 生命周期:EVP_MD_CTX_new()EVP_DigestInit_ex()EVP_DigestUpdate()EVP_DigestFinal_ex()EVP_MD_CTX_free()
  • libsodium 一行搞定:crypto_hash_sha256(out, in, inlen)out 是 32 字节缓冲区
  • OpenSSL 默认链接 libcrypto,Windows 下容易遇到 DLL 找不到错误;libsodium 是单头+单库,静态链接更干净

示例(OpenSSL):

unsigned char hash[SHA256_DIGEST_LENGTH];
EVP_MD_CTX *ctx = EVP_MD_CTX_new();
EVP_DigestInit_ex(ctx, EVP_sha256(), NULL);
EVP_DigestUpdate(ctx, "hello", 5);
EVP_DigestFinal_ex(ctx, hash, NULL);
EVP_MD_CTX_free(ctx);
// hash[] 现在含 32 字节二进制结果

别忽略输入长度和内存安全边界

SHA256 输入理论上无限长,但实际调用时,传入的 in 指针必须有效,长度 inlen 必须准确——尤其处理 std::string 时,别直接传 s.c_str() 而不传 s.length(),否则遇到内部 \0 就截断。

  • std::string 含二进制数据?用 s.data() + s.size(),不用 c_str()
  • std::vector<uint8_t></uint8_t> 存原始字节时,传 v.data()v.size(),别漏掉 .size()
  • 输出缓冲区至少 32 字节:OpenSSL 写满 32 字节;libsodium 也要求 out 至少 32 字节,不会自动分配
  • 别把输出当 C 字符串用:hash 里可能含 \0,printf("%s", hash) 会提前截断

Hex 编码要自己转,别指望库自动给字符串

所有主流 C++ 密码库返回的都是 32 字节二进制数据,不是 "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855" 这种 64 字符 hex 字符串。这一步必须手动做,且容易出错。

  • 别循环用 sprintf(buf, "%02x", hash[i])——栈缓冲区溢出风险高
  • 推荐用 std::ostringstream 或范围 for + std::format(C++20)
  • 注意大小写:FIPS 要求小写 hex,但有些旧系统期望大写,确认下游约定
  • 性能敏感场景(如日志高频打点),避免每次分配 string,可用预分配的 std::array<char></char> 手动填充

小示例(C++17):

std::string to_hex(const unsigned char* data, size_t len) {
    std::string s(len * 2, ' ');
    for (size_t i = 0; i < len; ++i)
        sprintf(&s[2*i], "%02x", data[i]);
    return s;
}

SHA256 计算本身很简单,真正卡住人的永远是链接、内存生命周期、二进制/文本边界这些“旁边的事”。尤其是 Windows 上 OpenSSL 的 DLL 路径、Android NDK 里 OpenSSL 版本碎片化、还有 hex 转换时大小写混用导致和 Python/JS 结果对不上——这些比算法本身花的时间多得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

870

2023.08.02

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

866

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

453

2024.06.27

printf用法大全
printf用法大全

php中文网为大家提供printf用法大全,以及其他printf函数的相关文章、相关下载资源以及各种相关课程,供大家免费下载体验。

76

2023.06.20

fprintf和printf的区别
fprintf和printf的区别

fprintf和printf的区别在于输出的目标不同,printf输出到标准输出流,而fprintf输出到指定的文件流。根据需要选择合适的函数来进行输出操作。更多关于fprintf和printf的相关文章详情请看本专题下面的文章。php中文网欢迎大家前来学习。

300

2023.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1560

2023.10.24

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.3万人学习

C 教程
C 教程

共75课时 | 5万人学习

C++教程
C++教程

共115课时 | 19.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号