6

再会。Stackoverflow 之前帮过我很多次,但是我有点卡在这个上,希望有人能给我一些指点。

背景:我需要将证书的 X509 数据传递给 Adob​​e 的 SDK CertListCab,以便使用我的 Acrobat 插件 api 签署 PDF。

我的问题是如何使用 CryptoAPI 从 PFX 证书中获取 X509 数据?

我做了以下事情:

  • 将我的 PFX 证书转换为内存存储。

    CRYPT_DATA_BLOB data;

  • 打开文件并填充数据。

    FILE *fIn = fopen("C:\\certificate\\MyPfx.pfx", "rb")
        fseek(fIn, 0, SEEK_END);
        data.cbData = ftell(fIn);
        fseek(fIn, 0, SEEK_SET);
        data.pbData = (BYTE *)malloc(data.cbData);
        fread(data.pbData, 1, data.cbData, fIn);
        fclose(fIn);
    

    HCERTSTORE hCertStore = PFXImportCertStore(&data, L"password", 0);

  • 找到证书。只有一个。

    PCCERT_CONTEXT hContext = CertFindCertificateInStore (hCertStore, X509_ASN_ENCODING | PKCS_7_ASN_ENCODING, 0, CERT_FIND_ANY, NULL, NULL);

  • 获取证书的公钥信息。

    BOOL bFreeHandle; HCRYPTPROV hProv; DWORD dwKeySpec; HCRYPTKEY hCertPubKey; CryptAcquireCertificatePrivateKey (hContext, 0, NULL, &hProv, &dwKeySpec, &bFreeHandle);

    CryptImportPublicKeyInfo(hProv, X509_ASN_ENCODING | PKCS_7_ASN_ENCODING, &hContext->pCertInfo->SubjectPublicKeyInfo, &hCertPubKey));

  • 现在我尝试为 X509 数据腾出空间。

    DWORD dwX509Len; BYTE *x509Data; CryptGetKeyParam(hCertPubKey,KP_CERTIFICATE,NULL,&dwX509Len,0);

    x509Data = (BYTE*)malloc(dwX509Len);

  • 我传入我的缓冲区。

    CryptGetKeyParam(hCertPubKey,KP_CERTIFICATE,x509Data,&dwX509Len,0);

当我运行我的程序时,我收到 CryptGetKeyParam 的错误:

NTE_BAD_TYPE : dwParam 参数指定一个未知值编号。

根据文档

KP_CERTIFICATE :pbData 是接收已使用可分辨编码规则 (DER) 编码的 X.509 证书的缓冲区的地址。证书中的公钥必须与相应的签名或交换密钥匹配。

难道我做错了什么?有没有其他方法可以获取 x509 数据?任何帮助,将不胜感激。

问候,玛格达

4

1 回答 1

3

看来我把问题复杂化了。

hContext->pbCertEncoded
hContext->cbCertEncoded

会给我我想要的数据。

还是不明白为什么 usingKP_CERTIFICATE没有检索到 X509 数据...

于 2013-05-09T09:33:00.533 回答