我需要一些关于 openssl 算法 Diffie Hellman 的帮助我有素数 (p)、生成器 (g)、用户 A 的私钥和用户 B 的公钥。我需要计算共享密钥。我写了这段代码,但代码一直执行到这一行
int dhSize = DH_size(dh->priv_key);
这是完整的代码:
#include <stdio.h>
#include <openssl/dh.h>
const char* userA_PrivateKey = "90ff0";
const char* userB_PublicKey = "9d1a59";
const char* p = "66c2fa";
const char* g = "2";
int main(void)
{
DH *dh = DH_new();
BN_dec2bn(&dh->g, g);
BN_hex2bn(&dh->p, p);
BN_hex2bn(&dh->priv_key, userA_PrivateKey);
BIGNUM *pubKeyUserB = NULL;
BN_dec2bn(&pubKeyUserB, userB_PublicKey);
//Compute the shared secret
int secret_size;
unsigned char *secret;
printf(" Compute DH_size \n");
int dhSize = DH_size(dh->priv_key);
printf(" dhSize = %d \n"); //NOT EXECUTED
secret = OPENSSL_malloc(sizeof(unsigned char) * dhSize);
if(0 > (secret_size = DH_compute_key(secret, pubKeyUserB, dh->priv_key)))
{
printf("error \n");
}
return 0;
}
我有两个问题:
1) 打印 dhSize 的 printf 根本没有执行
2) 我不确定我是否正确设置了 g, p, priv key 值?函数 DH_compute_key 会使用我的 g 和 p 吗?
你犯了愚蠢的错误:
dhSize
应该输入为DH_size
(~第 24 行)并且DH_size
函数计算struct DH
给定 a 的大小,const struct DH *
您正在传递它dh->priv_key
而不是传递它dh
(~第 28 行)
使用DH_compute_key
(~第 28 行)第三个参数时的类似错误应该dh
不是dh->priv_key
.
请相应地修复并重试
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句