gpt4 book ai didi

.net - 如何创建防止 "server mode SSL must use certificate with associated private key"异常的 X509 证书?

转载 作者:太空宇宙 更新时间:2023-11-03 13:50:59 62 4
gpt4 key购买 nike

我正在尝试创建一个 X.509 证书文件,该文件将与 smtp4dev 中的以下代码一起使用项目:

var certificate = new X509Certificate(Settings.Default.SSLCertificatePath);
var clientCertificateRequired = false;
var protocols = SslProtocols.Ssl2 | SslProtocols.Ssl3 | SslProtocols.Tls;
var checkRevocation = false;

var stream = new SslStream(stream);
stream.AuthenticateAsServer(certificate, clientCertificateRequired, protocols, checkRevocation);

Settings.Default.SSLCertificatePath 指向一个 .cer 文件。

无论我尝试什么,都会失败并出现 System.NotSupportedException 消息:

The server mode SSL must use a certificate with the associated private key.

我已经使用 New-SelfSignedCertificate 创建了一个 X509 证书提升的 PowerShell session 中的 PowerShell CommandLet:

New-SelfSignedCertificate `
-DnsName "localhost" `
-CertStoreLocation "cert:\CurrentUser\My" `
-FriendlyName "smtp4dev" `
-TextExtension "2.5.29.37={text}1.3.6.1.5.5.7.3.1" `
-KeyUsage DigitalSignature,KeyEncipherment,DataEncipherment `
-Provider "Microsoft RSA SChannel Cryptographic Provider"

我添加了这些选项以尽可能接近地镜像已存储在我的机器上的证书,该证书由 IIS Express 安装程序生成。因为那个特定的证书确实有效,尽管我不知道为什么。

这两个证书都位于 Local Computer > Personal 证书存储中。对于这两个证书,证书管理器都提到“您有一个与该证书相对应的私钥”。

当我比较这 2 个证书的属性时,smtp4dev 证书与 IIS Express 开发证书在以下 3 方面不同(除了指纹和序列号):

  • Key Usage 被标记为关键扩展
  • Subject Alternative Name extension with value DNS Name=localhost
  • 主题 key 标识符扩展值为 e7 12 f5 ...

我使用证书管理器将没有私钥的两个证书作为“Base-64 编码的 x.509 (.CER)”文件导出到我的桌面。 (包括私钥会将导出格式限制为 PKCS #12 (.PFX),smtp4dev 不支持该格式。)

以这种方式导出证书后,当我双击它们时,都没有显示关于拥有私钥的消息。

只有 IIS Express 开发证书适用于本问题开头显示的代码。 smtp4dev 没有。

我尝试过的其他事情:

  1. 我经常看到使用 makecert 的教程,但我没有那个程序。

  2. 我已经尝试使用由 openssl 生成的自签名证书,并且只将 Common Name 设置为 localhost 但我得到了同样的异常(exception)(“服务器模式 SSL 必须使用具有关联私钥的证书”)。

  3. 更改代码以使用 X509Certificate2 不是一个选项,因为应用补丁的 smtp4dev 的另一个版本将非常耗时,因为该项目似乎没有积极开发。

  4. 尝试不同的证书文件格式(例如 PFX)实际上是可以的,只要我将文件重命名为 .cer 就可以欺骗 smtp4dev 使用该证书。这允许我在证书中包含私钥。它适用于 IIS Express 开发证书的导出,但不适用于 smtp4dev 证书的导出。

最佳答案

只有一件事浮现在脑海: key 提供程序兼容性。 SslStream 似乎不支持 CNG KSP( key 存储提供程序),它是 New-SelfSignedCertificate` cmdlet 的默认 key 提供程序类型。

我建议在 PowerShell 调用中明确指定任何遗留提供程序:

New-SelfSignedCertificate `
-DnsName "localhost" `
-CertStoreLocation "cert:\LocalMachine\My" `
-FriendlyName "smtp4dev" `
-TextExtension "2.5.29.37={text}1.3.6.1.5.5.7.3.1" `
-KeyUsage DigitalSignature,KeyEncipherment,DataEncipherment `
-Provider "Microsoft RSA SChannel Cryptographic Provider"

关于.net - 如何创建防止 "server mode SSL must use certificate with associated private key"异常的 X509 证书?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45281590/

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