我想存储x509证书供Windows服务使用.我遇到的问题是在哪里存储此证书.似乎使用Microsoft管理控制台(mmc)证书管理单元可以使Windows服务具有特定的证书存储.问题是我无法弄清楚如何通过C#获得这些证书.使用mmc和证书...

我想存储x509证书供Windows服务使用.我遇到的问题是在哪里存储此证书.似乎使用Microsoft管理控制台(mmc)证书管理单元可以使Windows服务具有特定的证书存储.问题是我无法弄清楚如何通过C#获得这些证书.
>使用mmc和证书管理单元在服务存储下安装了证书.
使用topshelf使用以下代码创建并安装Windows服务:
var localStore = new X509Store(StoreLocation.LocalMachine);
localStore.Open(OpenFlags.ReadOnly);
foreach (X509Certificate2 c in localStore.Certificates)
{
_log.Debug("local: certificate for {0} - has private key {1}".ToFormat(c.SubjectName.Name, c.HasPrivateKey));
}
var userStore = new X509Store(StoreLocation.CurrentUser);
userStore.Open(OpenFlags.ReadOnly);
foreach (X509Certificate2 c in userStore.Certificates)
{
_log.Debug("user: certificate for {0} - has private key {1}".ToFormat(c.SubjectName.Name, c.HasPrivateKey));
}
我永远不会在Windows服务的商店中看到证书.如果我将证书添加到“本地计算机”证书存储中,则Windows服务会看到该证书.
mmc中所有用于向服务商店添加证书的工具都必须有一个目的.
解决方法:
Windows服务使用与运行MMC时不同的用户帐户运行,这就是为什么您在CurrentUser存储中看不到证书的原因.但请在LocalMachine商店中看到它.
解决此问题的一种方法是让Windows服务以特定用户的身份运行,例如“ ServiceX”.然后,您将MMC作为“ ServiceX”运行,并将证书添加到当前用户存储中.
本文标题为:使用C#访问Windows Service证书存储区中的x509证书


基础教程推荐
- C# 8.0中的范围类型(Range Type)示例详解 2023-01-06
- C#实现五子棋游戏 2022-12-09
- C#结束进程及子进程 2023-06-15
- Unity3D仿写Button面板事件绑定功能 2023-01-11
- C#跨平台开发之使用C/C++生成的动态链接库 2023-05-15
- C# StreamReader类实现读取文件的方法 2023-03-28
- Unity3D实现旋钮控制灯光效果 2023-01-22
- C#多线程之线程中止Abort()方法 2023-05-31
- 使用C#编写自己的区块链挖矿算法 2023-01-27
- NancyFx框架检测任务管理器详解 2022-11-22