使用非托管c++访问X509证书存储
Access X509 Certificate store with unmanaged C++
有人知道我如何使用非托管 c++执行以下c#代码的等效操作,即通过拇指指纹从X509证书存储查询证书吗?
var store = new X509Store(StoreName.My, StoreLocation.LocalMachine);
store.Open(OpenFlags.ReadOnly);
var allCerts = store.Certificates;
foreach (var certificate in from X509Certificate2 certificate in allCerts
where certificate.Thumbprint != null
&& certificate.Thumbprint.Equals(thumbprint, StringComparison.OrdinalIgnoreCase)
select certificate)
{
return certificate;
}
Thanks in advance
戴夫为了完成您想要的,您必须查看Win32 CryptAPI库。它不会像。net那样简单。查看CertOpenStore和certfindcertificatestore
您需要打开一个证书存储并将其传递给CertFindCertificateStore,创建一个结构来保存您想要用于查找证书的任何标准。您可以使用序列号、签名等。
HCERTSTORE hSysStore = NULL;
PCCERT_CONTEXT pDesiredCert = NULL;
if(hSysStore = CertOpenStore(
CERT_STORE_PROV_SYSTEM, // The store provider type
0, // The encoding type is
// not needed
NULL, // Use the default HCRYPTPROV
CERT_SYSTEM_STORE_CURRENT_USER, // Set the store location in a
// registry location
L"MY" // The store name as a Unicode
// string
))
{
//We have our store, let's do stuff with it
if (pDesiredCert = CertFindCertificateInStore(.....) { ..... }
}
else
{
//Error stuff
}
您需要#include <Wincrypt.h>
和#include <windows.h>
来自certfindcertificatestore的代码。将不能在较新的系统上工作。在较新的Windows版本中,证书的名称或主题采用Unicode格式,每个字符使用2个字节。下一行:
LPCSTR lpszCertSubject = (LPCSTR) "Cert_subject_1";
必须改为:
LPCWSTR lpszCertSubject = (LPCWSTR ) L"Cert_subject_1";
或
LPCTSTR lpszCertSubject = (LPCTSTR ) _T"Cert_subject_1"; // add #include <tchar.h>
相关文章:
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 用于访问容器<T>数据成员的正确 API
- 访问者访问变体并返回不同类型时出错
- 尝试通过多个向量访问变量时,向量下标超出范围
- 无法访问嵌套类.类的使用无效
- 写入位置0x0000000C时发生访问冲突
- 我们可以访问一个不存在的联盟的成员吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 我的简单if-else语句是如何无法访问的代码
- 从C++dll访问C#中的一行主要参数
- 概念TS检查忽略私有访问修饰符
- 访问被拒绝后,c++中的故障保护代码
- 在c++中访问int到类对象的映射时出错
- 我想访问std::unique_ptr中的一个特定元素
- 为什么示例代码访问IUnknown中已删除的内存
- C++:无法访问声明的受保护成员
- 通过指向指针数组的指针访问子类的属性
- 使用非托管c++访问X509证书存储