the underlying connection was closed:the server committed a protocol violation
Posted on 2010-04-11 07:57 Charles Chen 阅读(7324) 评论(0) 编辑 收藏 举报一、问题的产生:
在用C#从FTP服务器下载文件的过程中,出现一个莫名其妙的错误。(本机上测试正常,当部署到服务器上才出现,而且错误提示很奇怪)。
"the underlying connection was closed:the server committed a protocol violation" 翻译成中文是:"基础连接已经关闭: 服务器提交了协议"
当程序Throw出这个错误时候,真是无法理解.下面是程序代码: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