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设计
相关推荐
金銀銅鐵18 小时前
[Python] 扩展欧几里得算法Duckdblab18 小时前
DuckDB 性能调优终极指南:打造闪电般的分析体验带派擂总19 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误笃行35021 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战笃行35021 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救笃行35021 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环金銀銅鐵1 天前
n^5 和 n 的个位数是否总相等?aqi001 天前
15天学会AI应用开发(九)利用Chroma持久化向量数据