用密码学安全随机数生成256位密钥

核心原则

密码学安全随机数生成器(CSPRNG)需满足:

  1. 熵源来自系统底层(如硬件随机数、系统环境噪声);
  2. 不可预测、不可重现;
  3. 杜绝使用rand()等伪随机函数(仅用于非安全场景)。

使用CryptGenRandom(Windows CryptoAPI),系统级CSPRNG,支持 Windows XP 及以上。

cpp 复制代码
#include <windows.h>
#include <wincrypt.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>

// 生成256位(32字节)密码学安全随机密钥
int generate_aes256_key_win(uint8_t *key_out) {
    HCRYPTPROV hProv = 0;
    // 1. 获取加密服务提供器(CSP)句柄
    if (!CryptAcquireContext(&hProv, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT)) {
        fprintf(stderr, "CryptAcquireContext失败,错误码:%lu\n", GetLastError());
        return -1;
    }
    // 2. 生成32字节安全随机数(256位密钥)
    if (!CryptGenRandom(hProv, 32, key_out)) {
        fprintf(stderr, "CryptGenRandom失败,错误码:%lu\n", GetLastError());
        CryptReleaseContext(hProv, 0);
        return -1;
    }
    // 3. 释放资源
    CryptReleaseContext(hProv, 0);
    return 0;
}

// 测试:生成并打印256位密钥
int main() {
    uint8_t aes256_key[32] = {0};
    if (generate_aes256_key_win(aes256_key) != 0) {
        return -1;
    }
    printf("Windows生成的256位AES密钥(十六进制):\n");
    for (int i = 0; i < 32; i++) {
        printf("%02X ", aes256_key[i]);
        if ((i+1) % 8 == 0) printf("\n"); // 每8字节换行,便于阅读
    }
    return 0;
}
相关推荐
我在人间贩卖青春31 分钟前
C++之多重继承
c++·多重继承
m0_736919101 小时前
C++代码风格检查工具
开发语言·c++·算法
2501_944934731 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
玉梅小洋1 小时前
Windows 10 Android 构建配置指南
android·windows
黎雁·泠崖2 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
九河云2 小时前
5秒开服,你的应用部署还卡在“加载中”吗?
大数据·人工智能·安全·机器学习·华为云
2301_763472462 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
阿猿收手吧!3 小时前
【C++】std::promise原理与实战解析
c++
TechWJ3 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha3 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全