我有.pxf(AFAIK PKCS#12)证书。如何使用openssl C API确认此证书的给定密码?
答案 0 :(得分:8)
找到这样的答案的一种方法是找到一个OpenSSL实用程序,它执行与您尝试执行的操作相同的功能。在这种情况下,您可以使用OpenSSL附带的pkcs12实用程序来验证密码。
验证pfx文件的命令如下:
openssl pkcs12 -in mypfx.pfx -noout
根据该信息,您可以查看其source code({openssl_src}/apps/pkcs12.c
),了解他们是如何做到的。
源代码显示它调用PKCS12_verify_mac
来验证密码。首先要确认没有密码:
if( PKCS12_verify_mac(p12, NULL, 0) )
{
printf("PKCS12 has no password.\n");
}
然后如果有密码,请将其作为参数传递来验证:
if( PKCS12_verify_mac(p12, password, -1) )
{
printf("PKCS12 password matches.\n");
}
OpenSSL还有在openssl/demos/pkcs12
中使用PKCS12的演示。 pkread.c
演示提供了使用密码解析pfx文件的示例。
EVP_PKEY *pkey;
X509 *cert;
STACK_OF(X509) *ca = NULL;
if (!PKCS12_parse(p12, password, &pkey, &cert, &ca)) {
fprintf(stderr, "Error parsing PKCS#12 file\n");
ERR_print_errors_fp(stderr);
exit(1);
}
完整示例,使用gcc -std=c99 verifypfx.c -o verifypfx -lcrypto
编译:
#include <stdio.h>
#include <errno.h>
#include <openssl/pkcs12.h>
#include <openssl/err.h>
int main(int argc, char *argv[])
{
const char *password = "mypassword";
PKCS12 *p12;
// Load the pfx file.
FILE *fp = fopen("mypfx.pfx", "rb");
if( fp == NULL ) { perror("fopen"); return 1; }
p12 = d2i_PKCS12_fp(fp, NULL);
fclose(fp);
OpenSSL_add_all_algorithms();
ERR_load_PKCS12_strings();
if( p12 == NULL ) { ERR_print_errors_fp(stderr); exit(1); }
// Note: No password is not the same as zero-length password. Check for both.
if( PKCS12_verify_mac(p12, NULL, 0) )
{
printf("PKCS12 has no password.\n");
}
else if( PKCS12_verify_mac(p12, password, -1) )
{
printf("PKCS12 password matches.\n");
}
else
{
printf("Password not correct.\n");
}
return 0;
}
答案 1 :(得分:1)
使用PKCS12_verify_mac()
。例如
FILE* f = fopen("myfile.pfx", "rb");
PKCS12* p12 = d2i_PKCS12_fp(f, NULL);
fclose(f);
if (!PKCS12_verify_mac(p12, (char*)"mypassword", strlen("mypassword")))
{
// handle failure
}