gpt4 book ai didi

.net - 带有 TransferMode.Streamed 的 WCF NetTcpBinding 在 Windows Server 2019 上无法使用 TLS 1.2 和 SslProtocols.None 在 WCF 绑定(bind)上工作

转载 作者:太空宇宙 更新时间:2023-11-03 14:23:22 26 4
gpt4 key购买 nike

我们有一个 WCF 客户端和服务器,它们通过 WCF NetTcpBinding 与 Streamed Transfermode 进行通信,其中客户端使用以下相关设置设置 WCF NetTcpBInding:

TransferMode = TransferMode.Streamed
Security.Mode = SecurityMode.Transport
Security.Transport.ClientCredentialType = TcpClientCredentialType.Certificate
Security.Transport.SslProtocols = System.Security.Authentication.SslProtocols.None

根据 https://learn.microsoft.com/en-us/dotnet/framework/network-programming/tls , SslProtocols.None 确保 WCF 在使用 NetTcp 传输时使用操作系统默认设置。

我们所有的 Windows 主机都配置为仅允许 TLS 1.2。这已使用 Windows 注册表进行配置,并将所有服务器和客户端 key 设置为禁用 SSL 2.0、SSL 3.0n TLS 1.0 和 TLS 1.1,并仅在以下位置为 TLS 1.2 启用:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\SecurityProviders\SCHANNEL\Protocols,如 https://learn.microsoft.com/en-us/windows-server/security/tls/tls-registry-settings 中所述.

此外,我们的 WCF 客户端和服务器的 app.config 文件包含此运行时条目(如 https://learn.microsoft.com/en-us/configmgr/core/plan-design/security/enable-tls-1-2 中所述):

<configuration>
<runtime>
<AppContextSwitchOverrides value="Switch.System.ServiceModel.DisableUsingServicePointManagerSecurityProtocols=false;Switch.System.Net.DontEnableSchUseStrongCrypto=false" />
</runtime>
</configuration>

当 WCF 客户端在 Windows 10(内部版本 1809)上运行并且服务器在 Windows Server 2019 LTSC、.NET 版本 4.7.2 上运行时,WCF 通信工作正常。

当 WCF 客户端和服务器都在 Windows Server 2019 LTSC、.NET 4.7.2 上运行时,通信失败并出现以下异常:

Message: A call to SSPI failed, see inner exception.
Title:The file information could not be gathered.
Inner Exception 1: A call to SSPI failed, see inner exception.
Inner Exception 2: The client and server cannot communicate, because they do not possess a common algorithm

Server stack trace:
at System.ServiceModel.Channels.SslStreamSecurityUpgradeInitiator.OnInitiateUpgrade(Stream stream, SecurityMessageProperty& remoteSecurity)
at System.ServiceModel.Channels.StreamSecurityUpgradeInitiatorBase.InitiateUpgrade(Stream stream)
at System.ServiceModel.Channels.ConnectionUpgradeHelper.InitiateUpgrade(StreamUpgradeInitiator upgradeInitiator, IConnection& connection, ClientFramingDecoder decoder, IDefaultCommunicationTimeouts defaultTimeouts, TimeoutHelper& timeoutHelper)
at System.ServiceModel.Channels.StreamedFramingRequestChannel.SendPreamble(IConnection connection, TimeoutHelper& timeoutHelper, ClientFramingDecoder decoder, SecurityMessageProperty& remoteSecurity)
at System.ServiceModel.Channels.StreamedFramingRequestChannel.StreamedConnectionPoolHelper.AcceptPooledConnection(IConnection connection, TimeoutHelper& timeoutHelper)
at System.ServiceModel.Channels.ConnectionPoolHelper.EstablishConnection(TimeSpan timeout)
at System.ServiceModel.Channels.StreamedFramingRequestChannel.StreamedFramingRequest.SendRequest(Message message, TimeSpan timeout)
at System.ServiceModel.Channels.RequestChannel.Request(Message message, TimeSpan timeout)
at System.ServiceModel.Dispatcher.RequestChannelBinder.Request(Message message, TimeSpan timeout)
at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs, TimeSpan timeout)
at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall, ProxyOperationRuntime operation)
at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message)

我们能够通过在设置客户端 NetTcpBinding 时显式设置 Security.Transport.SslProtocols 来解决问题,而不是让操作系统决定,像这样:

Security.Transport.SslProtocols = System.Security.Authentication.SslProtocols.Tls12 Or System.Security.Authentication.SslProtocols.Tls11 Or System.Security.Authentication.SslProtocols.Tls Or System.Security.Authentication.SslProtocols.Ssl3

我们不明白为什么这个解决方案有效,因为我们希望这个修复与让操作系统选择具有相同的效果。

在所有主机上仅允许 TLS 1.2 的情况下,当客户端和服务器都在 Windows Server 2019 上运行而不是客户端在 Windows 10 上运行时,通信怎么会失败?除了默认的 TLS 1.2 之外,别无其他。如何调查 Windows 默认使用哪种协议(protocol)?

最佳答案

首先,在这篇官方文章中,不建议我们指定或干预操作系统选择使用的SSL/TLS版本。不要使用 Windows 注册表或其他方法禁用某些 SSL/TLS 版本。
https://learn.microsoft.com/en-us/dotnet/framework/network-programming/tls
在我看来,服务端和客户端使用的SSL/TLS版本需要一个协商的过程。当客户端没有禁用其他版本的协议(protocol)时,即使客户端指定了SSL/TLS版本,也是由协商过程决定的。
此外,我们应该使用 Wireshark 网络协议(protocol)分析器检查通信过程中使用的 SSL/TLS 版本。
https://www.wireshark.org/
enter image description here
如果有什么我可以帮忙的,请随时告诉我。

关于.net - 带有 TransferMode.Streamed 的 WCF NetTcpBinding 在 Windows Server 2019 上无法使用 TLS 1.2 和 SslProtocols.None 在 WCF 绑定(bind)上工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58918284/

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