AES加密配置结构体时,密钥须从安全源获取、IV每次随机生成并随密文保存;仅对POD结构体直接序列化,含std::string等需手动序列化;.enc文件须定义固定头包含magic、cipher_id、IV和tag长度;GCM模式必须保存认证标签;缓冲区需预留足够空间,错误须用ERR_print_errors_fp排查。用 AES 加密配置结构体前,先确认密钥和 IV 怎么来硬编码密钥或固定 IV 是最常见也最危险的做法------加密形同虚设。AES 的安全性完全依赖密钥保密性和 IV 的不可预测性。生产环境必须从安全来源获取:比如系统密钥库(Windows DPAPI、macOS Keychain)、硬件模块(TPM),或至少由用户口令派生(用 PBKDF2 或 scrypt)。IV 每次加密都得重新生成,且必须和密文一起保存(通常前置 16 字节),不能复用。IV 必须是随机的,用 std::random_device + std::uniform_int_distribution 填充,别用 time(0)密钥长度要匹配算法:AES-128 要 16 字节,AES-256 要 32 字节;少一字节都会导致 EVP_EncryptInit_ex 返回失败OpenSSL 1.1.1+ 推荐用 EVP_AEAD 接口,比老式 EVP_Encrypt* 更难误用序列化配置数据时,避免直接 memcpy 结构体到内存C++ 结构体有对齐填充、虚函数表指针、非 POD 类型成员(如 std::string、std::vector),直接二进制 dump 会写入垃圾内存或指针地址,解密后无法还原。只对纯 POD 结构体(如仅含 int、double、char32)做 reinterpret_cast<const uint8_t*>(&cfg)含 std::string 的配置,必须手动序列化:先写长度(uint32_t),再写内容字节推荐用 flatbuffers 或 protobuf 生成二进制 schema,比手写序列化更可靠加密前务必计算真实有效字节数,别把整个 sizeof(cfg) 当作明文字节数传给 OpenSSL写 .enc 文件时,文件头格式决定后续能否正确解密.enc 不是标准格式,你得自己定义最小可用头。否则几年后连自己都读不懂------比如不知道用的是 AES-128-CBC 还是 AES-256-GCM,IV 在哪,认证标签多长。 Trenz AI驱动的社交电商营销平台,专为TikTok Shop设计
相关推荐
KobeSacre5 分钟前
JVM ZGCPsycho_MrZhang8 分钟前
Codex 高效开发协作手册HappyAcmen20 分钟前
1.pdfplumber安装,PDF文字提取弹简特21 分钟前
【零基础学Python-收尾】10-Python第三方库的安装介绍itfallrain34 分钟前
Spring 构造器循环依赖排查:@RequiredArgsConstructor + @Lazy 到底有没有生效Database_Cool_1 小时前
AnalyticDB MySQL vs StarRocks/ByteHouse:云数仓选型指南——全托管 vs 自建方案小草cys1 小时前
NVIDIA 驱动(550版本)成功安装后安装支持 GPU 加速的 PyTorchSilentSamsara1 小时前
Python 微服务全链路:gRPC + 链路追踪 + 服务网格接入Omics Pro1 小时前
「自兹以往」动物肠道微生物组zzz_23681 小时前
【Redis】分布式锁完整演进