如何使用CryptoAPI从p7b证书中提取公用密钥
问题描述:
我有一个p7b证书存储区。我打开它如何使用CryptoAPI从p7b证书中提取公用密钥
$HCERTSTORE cert_store_handle = CertOpenStore(
CERT_STORE_PROV_PKCS7,
PKCS_7_ASN_ENCODING,
NULL,
CERT_STORE_OPEN_EXISTING_FLAG | CERT_STORE_READONLY_FLAG,
&opm_data_blob
);
我做证书链验证,它可以,直到我必须从叶证书提取公钥。 我打电话
CryptDecodeObject(X509_ASN_ENCODING | PKCS_7_ASN_ENCODING, RSA_CSP_PUBLICKEYBLOB, (BYTE*) pubkey + 46, pubkey_len - 46, CRYPT_DECODE_NO_SIGNATURE_BYTE_REVERSAL_FLAG, NULL, &pubkey_decoded_size);
但它返回ASN1错误标记错误。
所以我尝试下面的代码:
{
BOOL crypt_res = FALSE;
HCRYPTPROV crypt_prov_hndl = NULL;
crypt_res = CryptAcquireContext(&crypt_prov_hndl, NULL, NULL, PROV_RSA_FULL, 0/*CRYPT_NEWKEYSET*/);
if (!crypt_res) {
HRESULT decode_hr = __HRESULT_FROM_WIN32(GetLastError());
return decode_hr;
}
HCRYPTKEY crypt_key_hndl = NULL;
crypt_res = CryptImportPublicKeyInfoEx(crypt_prov_hndl, X509_ASN_ENCODING, signer_public_key, CALG_RSA_SIGN, 0, NULL, &crypt_key_hndl);
if (!crypt_res) {
HRESULT decode_hr = __HRESULT_FROM_WIN32(GetLastError());
return decode_hr;
}
crypt_res = CryptReleaseContext(crypt_prov_hndl, 0);
}
,它工作正常,但我仍然不知道如何提取公钥。
有什么建议吗?
答
打开证书存储区后,
枚举所有证书的证书存储,CertEnumCertificatesInStore
,
一旦你感兴趣的证书的情况下,你可以在CERT_INFO
结构访问你的公钥。
当你“提取”它时,你希望你的公钥得到的任何特定格式? – 2011-06-14 06:53:01