the underlying connection was closed:the server committed a protocol violation

一、问题的产生: 

    在用C#从FTP服务器下载文件的过程中,出现一个莫名其妙的错误。(本机上测试正常,当部署到服务器上才出现,而且错误提示很奇怪)。

"the underlying connection was closed:the server committed a protocol violation" 翻译成中文是:"基础连接已经关闭: 服务器提交了协议"

当程序Throw出这个错误时候,真是无法理解.下面是程序代码:
代码
            ftpAddress = "ftp://192.168.1.1/0409/1234****.jpg";
            Uri serverUri = new Uri(ftpAddress);

            WebClient listRequest 
= new WebClient();
            listRequest.Credentials 
= new NetworkCredential("user""pwd");
            
try
            {
                
byte[] newImageFile = listRequest.DownloadData(serverUri);
                
return GenerateImgSrc(newImageFile);
            }
            
catch (Exception ex)
            {
                
throw ex;
            }

就是上面的代码段出现的提示,本机执行没有问题。当我在服务器上通过跟踪发现是由于listRequest.DownloadData()这个方法抛出的异常。

二、问题的原因:

通过在部署的服务器上进行多次测试,发现是由于在通过FTP下载文件的过程中返回了非法字符,导致DownLoadData报错。

可为什么在本机没有问题呢?我本机是在.Net Framework 2.0的环境下开发的。服务器上也是部署的是.Net Framework 2.0。是环境发生变化的差异吗?

我想到了是不是我本机其他Framework影响了在本机能正常运行,在服务器上因只有.Net Framework 2.0而无法正常运行。

突然我想到了版本问题,会不会.Net Framewrok 2.0的版本不同呢?我用的是WebClient.DownloadData方法是在System.dll程序集的的命名空间里。打开目录C:\Windows\Microsoft.NET\Framework\v2.0.50727\System.dll。发现服务器上的版本是:2.0.50727.42,而我本机的版本是:2.0.50727.4016,而且文件大小也不同。

最后:终于找到了在服务器上不能正常运行的原因呢?虽然都是.Net Framework 2.0,但是本机和服务器上的版本是不同的。

三、解决方法:

打上.Net Framework 2.0 SP1,部署的服务器上能够正常运行。

通过在服务器上安装.Net Framework 2.0 SP1后,果然发现System.dll的版本变化了,变成:2.0.50727.1433。虽然和我本机的版本还是不同,但是通过WebClient.DownloadData就能正常的下载了!

最后:上面的问题是在实际上项目中发现了。在这里只是做为一个开发笔记。方便以后查找。同时也希望提供给朋友们一种解决问题的一种思想。

(本机和服务器的环境由于安装不同的软件和框架,导致了程序运行的环境是不同的,通过怎样的思考来找出两端的差异性,这是一种有效的解决问题的方式)。

Best Regards,

Charles Chen

原文地址:https://www.cnblogs.com/Charles2008/p/1709349.html