gpt4 book ai didi

c# - 如何通过代码通过 tcp 绑定(bind)为 WCF 服务附加证书

转载 作者:太空宇宙 更新时间:2023-11-03 15:00:30 25 4
gpt4 key购买 nike

我得到了一个示例代码,它显示了如何通过编码将证书附加到带有 tcp 绑定(bind)的 WCF 服务。

NetTcpBinding b = new NetTcpBinding(SecurityMode.TransportWithMessageCredential);
b.Security.Message.ClientCredentialType = MessageCredentialType.Certificate;
Uri netTcpAdddress = new Uri("net.tcp://baseAddress");
ServiceHost sh = new ServiceHost(typeof(Calculator), netTcpAdddress);
sh.Credentials.ServiceCertificate.SetCertificate(
StoreLocation.LocalMachine, StoreName.My,
X509FindType.FindByIssuerName, "Contoso.com");
sh.AddServiceEndpoint(typeof(ICalculator), b, "TcpCalculator");
sh.Open();

我在想这行是什么意思

sh.Credentials.ServiceCertificate.SetCertificate(
StoreLocation.LocalMachine, StoreName.My,
X509FindType.FindByIssuerName, "Contoso.com");

wcf 服务运行的地方可能有很多证书存在于那台电脑上。如何提及我的服务需要附加哪个证书?

StoreLocation.LocalMachine 是什么意思?是本地主机的意思吗?

StoreName.My 是什么意思?

我的是什么?它是任何文件夹名称如果是那么这个文件夹的完整路径是什么。

X509FindType.FindByIssuerName 是什么?

这意味着什么,因为单个用户可以创建或拥有多个证书。那么我该如何指向特定的证书呢?

我可以创建许多证书,其中我可以使用“Contoso.com”这个词

我的问题是如何以编程方式指定或识别特定证书,因为用户可能会创建许多证书,所以我如何通过代码区分两个证书。

谢谢

最佳答案

这是关于 SetCertificate 的文档有问题的方法。看来我之前关于 SSL over TCP 的提示帮助了。

what is the meaning of StoreLocation.LocalMachine ? does it mean localhost ?

不,这并不意味着本地主机。它指的是分配给本地计算机(MMC snap-in 中的计算机帐户)的 X.509 证书存储。

what is the meaning of StoreName.My ?

指的是个人证书的X.509证书库。

what is My ? is it any folder name if yes then what is the full path of this folder.

My 在此特定实例中指的是本地计算机的个人证书存储。这是 MMC 中的结构 View 。

enter image description here

what is X509FindType.FindByIssuerName ?

这意味着您在主机上设置的证书将是与您提供的值的 IssuerName 匹配的第一个证书,即 "Contoso.com" . SetCertificate 将尝试在Local MachinePersonal 证书存储中查找符合此条件的证书。

what does it means because a single user may create or have many certificate. so how do i point to a specific certificate ?

正如您所建议的,如果运行主机的机器具有来自同一颁发者的多个证书,则 IssuerName 可能不是唯一标识符。使用另一个 X509FindType 会好得多枚举成员,例如 FindBySerialNumber 或更好的 FindByThumbprint

因此,这就是我如何唯一标识要在本地计算机的个人证书存储中的主机上设置的证书。

sh.Credentials.ServiceCertificate.SetCertificate(
StoreLocation.LocalMachine, StoreName.My,
X509FindType.FindByThumbprint,
/* Thumbprint - SHA1 hash value for the Cert */);

关于c# - 如何通过代码通过 tcp 绑定(bind)为 WCF 服务附加证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22832454/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com