如何解决如何使用CryptoAPI从p7b证书中提取公钥
|| 我有一个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,&pubkey_decoded_size);
但它会返回ASN1错误标签错误。
所以我尝试下面的代码:
{
BOOL crypt_res = FALSE;
HCRYPTPROV crypt_prov_hndl = NULL;
crypt_res = CryptAcquireContext(&crypt_prov_hndl,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,&crypt_key_hndl);
if (!crypt_res) {
HRESULT decode_hr = __HRESULT_FROM_WIN32(GetLastError());
return decode_hr;
}
crypt_res = CryptReleaseContext(crypt_prov_hndl,0);
}
并且工作正常,但我仍然不知道如何提取公钥。
有什么建议么?
解决方法
打开证书存储区后,
枚举证书存储区“ѭ3”中的所有证书,
一旦获得了感兴趣的证书的上下文,就可以在“ 4”结构中访问您的公共密钥。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。