我一直无法找到关于在 openssl/bn.h 中使用 BN_generate_prime 生成素数的答案。另外,我如何播种该函数使用的 PRNG?
单独的问题但与我的代码相关(我正在编写一个程序来生成 RSA 密钥对):如何检查高位是否设置为 BIGNUM?假设我生成一个 512 位素数。我会使用 BN_is_bit_set(prime, 512) 吗?
Thanks
BN_generate_prime 是一个已弃用的函数,说here https://www.openssl.org/docs/crypto/BN_generate_prime.html。此外,它是在 crypto/bn_depr.c 中定义的。你不应该用它来生成素数。相反,您应该使用 BN_generate_prime_ex。以下是 BN_generate_prime_ex 的示例用法:
BIGNUM *r;
static const char rnd_seed[] = "string to make the random number generator think it has entropy";
r = BN_new();
RAND_seed(rnd_seed, sizeof rnd_seed); /* or BN_generate_prime_ex may fail */
BN_generate_prime_ex(r, 512, 0, NULL, NULL, NULL);
BN_free(r);
然后你将得到一个 512 位伪随机素数。如上面的示例,您可以通过 RAND_seed 为 PRNG 播种。
对于第二个问题,尝试BN_num_bits http://www.openssl.org/docs/crypto/BN_num_bytes.html.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)