我正在使用一个商业应用程序,它抛出了一个SocketException消息,

远程主机强制关闭现有连接

这发生在客户端和服务器之间的套接字连接上。连接是正常的,并且正在传输大量数据,但随后突然断开连接。

有人见过这个吗?原因可能是什么?我能猜到一些原因,但是有没有办法在这段代码中添加更多的原因来找出原因是什么?

欢迎任何评论/想法。

... 最新的…

我有一些日志从一些。net跟踪,

System.Net.Sockets Verbose: 0 : [8188] Socket#30180123::Send() DateTime=2010-04-07T20:49:48.6317500Z

System.Net.Sockets Error: 0 : [8188] Exception in the Socket#30180123::Send - An existing connection was forcibly closed by the remote host DateTime=2010-04-07T20:49:48.6317500Z 

System.Net.Sockets Verbose: 0 : [8188] Exiting Socket#30180123::Send() -> 0#0

根据日志记录的其他部分,我看到了这样一个事实:它说0#0意味着正在发送一个长度为0字节的数据包。但这到底是什么意思呢?

有两种可能,我不确定是哪一种,

连接正在关闭,但随后数据正在写入套接字,从而创建了上述异常。0#0仅仅意味着没有发送任何东西,因为套接字已经关闭。 连接仍然是打开的,并且正在发送一个零字节的数据包(即代码有一个错误),而0#0意味着一个零字节的数据包正在试图发送。

你怎么看?我猜这可能是不确定的,但也许有人见过这种东西?


当前回答

我也遇到了同样的问题,并最终设法解决了它。在我的例子中,客户端发送请求的端口没有与之绑定SSL证书。因此,我通过将SSL证书绑定到服务器端的端口来解决这个问题。一旦完成了这个操作,这个异常就消失了。

其他回答

使用TLS 1.2解决了这个错误。 你可以强制你的应用程序使用TLS 1.2(确保在调用你的服务之前执行它):

ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12 

另一个解决方案: 在您的本地机器或服务器中启用强加密以使用TLS1.2,因为默认情况下它是禁用的,因此只使用TLS1.0。 要启用强加密,在PowerShell中以管理员权限执行以下命令:

Set-ItemProperty -Path 'HKLM:\SOFTWARE\Wow6432Node\Microsoft\.NetFramework\v4.0.30319' -Name 'SchUseStrongCrypto' -Value '1' -Type DWord
Set-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\.NetFramework\v4.0.30319' -Name 'SchUseStrongCrypto' -Value '1' -Type DWord 

您需要重新启动计算机才能使这些更改生效。

在我的情况下,启用IIS服务器,然后重新启动并再次检查。

我在使用. net Framework 4.5时遇到了同样的问题。但是,当我将. net版本更新到4.7.2时,连接问题就解决了。也许这是由于安全协议支持的问题。

得了同样的毛病。实际上工作的情况下,流量被发送使用一些代理(提琴手在我的情况下)。更新。net框架从4.5.2到>=4.6,现在一切正常。实际的请求是: 新的WebClient () .DownloadData(“URL”); 唯一的例外是:

命令强制关闭现有连接 远程主机

我试图使用GO客户端连接到MQTT代理, 代理地址是地址+端口,或者tcp://地址:端口

例如:❌

mqtt://test.mosquitto.org

这表明您希望建立一个未加密的连接。

要通过TLS请求MQTT,请使用ssl、TLS、mqtts、MQTT +ssl或tcp之一。

例如:✅

mqtts://test.mosquitto.org