c# - 在 C# 中将证书安装到 Windows 本地用户证书存储区

标签 c# windows certificate certificate-store

我正在编写一个 Windows 服务,它需要证书存储中的多个证书才能连接到第三方 Web 服务。

在我的安装程序中,我调用了一个小应用程序 (C#),它创建了一个用户来运行服务。

它工作正常。

我现在需要将大约 10 个证书(不要问!)安装到用户证书存储中,但找不到任何简洁的编程方式来执行此操作。

有什么提示吗?还是我必须使用 COM互操作...

最佳答案

原来你首先需要模拟用户。

使用 A small C# Class for impersonating a User 中描述的非常好的库,您可以执行以下操作:

using (new Impersonator("username", "", "password"))
{
    try
    {
        X509Store serviceRuntimeUserCertificateStore = new X509Store(StoreName.My);
        string baseDir = AppDomain.CurrentDomain.BaseDirectory;
        string certPath = Path.Combine(baseDir, certificateFolder);

        string certificateFile = "c:\\file.cert";
        string certificatePassword = "somePassword";
        string certificateLocation = certPath + "\\" + certificateFile;

        InstallCertificate(certificateLocation, certificatePassword);
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex);
    }
}

private static void InstallCertificate(string certificatePath, string certificatePassword)
{
    try
    {
        var serviceRuntimeUserCertificateStore = new X509Store(StoreName.My);
        serviceRuntimeUserCertificateStore.Open(OpenFlags.ReadWrite);

        X509Certificate2 cert;

        try
        {
            cert = new X509Certificate2(certificatePath, certificatePassword);
        }
        catch(Exception ex)
        {
            Console.WriteLine("Failed to load certificate " + certificatePath);
            throw new DataException("Certificate appeared to load successfully but also seems to be null.", ex);
        }

        serviceRuntimeUserCertificateStore.Add(cert);
        serviceRuntimeUserCertificateStore.Close();
    }
    catch(Exception)
    {
        Console.WriteLine("Failed to install {0}.  Check the certificate index entry and verify the certificate file exists.", certificatePath);
    }
}

请添加您自己的异常处理。如果您要添加多个证书,请在此期间保持 X509Store 打开以提高效率。

关于c# - 在 C# 中将证书安装到 Windows 本地用户证书存储区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/308554/

相关文章:

google-chrome - SSL 证书 "err_cert_authority_invalid"仅适用于移动版 chrome

c# - 如何在多线程环境中只执行一次代码块?

c# - 将 DateTimeOffset 转换为 DateTime 并为此 DateTime 添加偏移量

c# - jQuery post 数组 - ASP.Net MVC 4

c++ - 使用 wuapi 获取 Windows 系统更新

windows - 是否可以在Windows CE 5.0 浏览器中查看部署在IIS 6.0 上的silverlight 或asp.net 3.5 网站?

ssl - 哈希签名证书的格式

c# - 等效于 C# 的 C 代码,用于安装证书

c# - 避免 Visual Studio 在特定区域自动格式化代码

c# - 在鼠标悬停事件上突出显示列表框项目