我有一个程序,如下所示:
EVP_PKEY *generate_RSA_key_and_uuid(unsigned char uuid[16])
{
EVP_PKEY *key_p;
key_p = EVP_PKEY_new();
return key_p;
}
int build_and_save_csr(int dn_entries, X509_REQ *req_p, EVP_PKEY *priv_key_p, char *passphrase)
{
priv_key_p = generate_RSA_key_and_uuid(uuid);
}
int makecsr(X509_REQ *req_p, EVP_PKEY *priv_key_p, char *passphrase)
{
if (build_and_save_csr(2, req_p, priv_key_p, passphrase) != 0) {
fprintf(stderr, "Could not create csr file / private key...\n");
exit(1);
}
return 0;
}
int main(int argc, char *argv[])
{
EVP_PKEY *priv_key_p;
X509_REQ *req_p;
makecsr(req_p, priv_key_p, passphrase);
return 0;
}
运行之后,*priv_key_p
应该包含从返回的值*generate_RSA_key_and_uuid
.
在 gdb 中,我可以在末尾看到generate_RSA_and_uuid
that key_p
包含正确的值,但之后priv_key_p = generate_RSA_key_and_uuid(uuid);
已执行,priv_key_p
是空的。
有谁知道如何正确地将值分配给指针?
您需要额外的间接级别,否则您只是修改指针的本地副本,并且不会返回任何内容:
int build_and_save_csr(int dn_entries, X509_REQ *req_p, EVP_PKEY **priv_key_p, char *passphrase)
{
*priv_key_p = generate_RSA_key_and_uuid(uuid);
}
int makecsr(X509_REQ *req_p, EVP_PKEY **priv_key_p, char *passphrase)
{
if (build_and_save_csr(2, req_p, priv_key_p, passphrase) != 0) {
fprintf(stderr, "Could not create csr file / private key...\n");
exit(1);
}
return 0;
}
int main(int argc, char *argv[])
{
EVP_PKEY *priv_key_p;
X509_REQ *req_p;
makecsr(req_p, &priv_key_p, passphrase);
return 0;
}
或者,您可以使用函数结果(就像您已经在generate_RSA_key_and_uuid()
)返回指针(可能在错误时返回 NULL)——这消除了对额外间接级别的需要。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)