我可以使用以下声明在特定商店中获取证书。
X509Store.Certificates
但不确定如何获取当前用户或本地计算机下的证书存储名称列表。我还检查了StoreName枚举,但它只列出了标准商店名称,但没有列出用户定义的名称。
我想要CERTIFICATE STORES列表,而不是特定商店中的证书列表。
答案 0 :(得分:10)
http://msdn.microsoft.com/en-us/library/aa376058(VS.85).aspx
不要认为这是一种托管的.net方式。可能最接近的可能是使用.net的注册表函数从注册表中读取商店名称?
答案 1 :(得分:3)
您可以从C#代码调用Powershell脚本。下面是一个示例函数(您需要在项目中添加对System.Management.Automation程序集的引用),该函数返回LocalMachine的证书存储列表:
private static String[] GetLocalMachineStoresNames()
{
List<String> names;
using (RunspaceInvoke runtimeInvoke = new RunspaceInvoke())
{
Collection<PSObject> results = runtimeInvoke.Invoke(@" cd cert:\LocalMachine; dir | % { $_.Name }");
names = new List<String>();
for (Int32 q = 0; q < results.Count; q++)
{
names.Add(results[q].BaseObject.ToString());
}
}
return names.ToArray();
}
答案 2 :(得分:1)
正如dotalchemy所提到的,你必须从注册表中读取名称。查看以下网站的位置: https://msdn.microsoft.com/en-us/library/windows/desktop/aa388136(v=vs.85).aspx
例如,CERT_SYSTEM_STORE_LOCAL_MACHINE位于
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\SystemCertificates
以下是如何获取名称/商店
using (var rootKeySystemCertificates = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SOFTWARE\\Microsoft\\SystemCertificates", false))
{
foreach (var subKeyName in rootKeySystemCertificates.GetSubKeyNames())
{
var store = new X509Store(subKeyName, StoreLocation.LocalMachine);
store.Open(OpenFlags.ReadOnly);
//your part with store.Certificates...
store.Close();
}
}