静脉模拟终止调用 openssl ECDSA_SIG_get0 函数
Veins simulation terminates calling openssl ECDSA_SIG_get0 function
我在 VirtualBox 上使用虚拟机 instant-veins-4-7-1-i1
Omnet++-5.3
和 Sumo-0.32.0
。
我已经安装了库 openssl
版本 1.1.0。当我尝试访问使用函数 ECDSA_SIG_get0
存储签名的结构 ECDSA_SIG
时,模拟突然终止并出现以下错误
这是生成错误的代码片段:
ECDSA_SIG * signed_hash;
s->generateSignature(message, messageLength, signed_hash);
const BIGNUM **pr;
const BIGNUM **ps;
ECDSA_SIG_get0(signed_hash, pr, ps);
generateSignature
函数代码为:
void SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength, ECDSA_SIG * signed_hash)
{
unsigned char *md;
unsigned char *hash;
hash = SHA256(message, messageLength, md);
// Computes the ECDSA signature of the given message using the supplied private key and returns the created signature
signed_hash = ECDSA_do_sign(hash, 32, eckey);
if (signed_hash == NULL){
std::cout <<" ko signature " << std::endl;
}else{
std::cout <<" ok signature" << std::endl;
}
}
我已将 openssl
库升级到 1.1.1 版,但错误仍然存在。
我做错了什么?
谢谢
您的问题与 openssl 无关,而是您的 "C" 代码和您对指针的误用。
您的问题行是:
signed_hash = ECDSA_do_sign(hash, 32, eckey);
您的代码假定它正在更改调用函数中的指针,但事实并非如此。它只是改变指针的 "copy" 。您想要 return 指针或传入指向指针的指针并以这种方式设置它。
例如
ECDSA_SIG *SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength)
{
...
ECDSA_SIG * signed_hash = ECDSA_do_sign(hash, 32, eckey);
...
return signed_hash;
}
ECDSA_SIG * signed_hash = s->generateSignature(message, messageLength);
或
void SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength, ECDSA_SIG ** signed_hash)
{
...
*signed_hash = ECDSA_do_sign(hash, 32, eckey);
if (*signed_hash == NULL){
std::cout <<" ko signature " << std::endl;
}else{
std::cout <<" ok signature" << std::endl;
}
}
ECDSA_SIG * signed_hash;
s->generateSignature(message, messageLength, &signed_hash);
我在 VirtualBox 上使用虚拟机 instant-veins-4-7-1-i1
Omnet++-5.3
和 Sumo-0.32.0
。
我已经安装了库 openssl
版本 1.1.0。当我尝试访问使用函数 ECDSA_SIG_get0
存储签名的结构 ECDSA_SIG
时,模拟突然终止并出现以下错误
这是生成错误的代码片段:
ECDSA_SIG * signed_hash;
s->generateSignature(message, messageLength, signed_hash);
const BIGNUM **pr;
const BIGNUM **ps;
ECDSA_SIG_get0(signed_hash, pr, ps);
generateSignature
函数代码为:
void SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength, ECDSA_SIG * signed_hash)
{
unsigned char *md;
unsigned char *hash;
hash = SHA256(message, messageLength, md);
// Computes the ECDSA signature of the given message using the supplied private key and returns the created signature
signed_hash = ECDSA_do_sign(hash, 32, eckey);
if (signed_hash == NULL){
std::cout <<" ko signature " << std::endl;
}else{
std::cout <<" ok signature" << std::endl;
}
}
我已将 openssl
库升级到 1.1.1 版,但错误仍然存在。
我做错了什么?
谢谢
您的问题与 openssl 无关,而是您的 "C" 代码和您对指针的误用。
您的问题行是:
signed_hash = ECDSA_do_sign(hash, 32, eckey);
您的代码假定它正在更改调用函数中的指针,但事实并非如此。它只是改变指针的 "copy" 。您想要 return 指针或传入指向指针的指针并以这种方式设置它。
例如
ECDSA_SIG *SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength)
{
...
ECDSA_SIG * signed_hash = ECDSA_do_sign(hash, 32, eckey);
...
return signed_hash;
}
ECDSA_SIG * signed_hash = s->generateSignature(message, messageLength);
或
void SignatureOpenSSL::generateSignature(const unsigned char* message, int messageLength, ECDSA_SIG ** signed_hash)
{
...
*signed_hash = ECDSA_do_sign(hash, 32, eckey);
if (*signed_hash == NULL){
std::cout <<" ko signature " << std::endl;
}else{
std::cout <<" ok signature" << std::endl;
}
}
ECDSA_SIG * signed_hash;
s->generateSignature(message, messageLength, &signed_hash);