获取C#中的证书存储名称列表

时间:2010-10-27 19:29:36

标签: c# certificate-store

我可以使用以下声明在特定商店中获取证书。

X509Store.Certificates

但不确定如何获取当前用户或本地计算机下的证书存储名称列表。我还检查了StoreName枚举,但它只列出了标准商店名称,但没有列出用户定义的名称。

我想要CERTIFICATE STORES列表,而不是特定商店中的证书列表。

3 个答案:

答案 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();
    }
}