【发布时间】:2017-01-19 03:31:07
【问题描述】:
我正在使用以下代码从 FTP 服务器下载文件。但无论如何,我总是收到超时消息。
ftpo = System.Net.WebRequest::Create("ftp://myserver.com/subFolder/filename.txt");
request = ftpo;
credential = new System.Net.NetworkCredential(_user, _password);
request.set_Credentials(credential);
request.set_KeepAlive(false);
request.set_Method(_ftpMethod);
request.set_UsePassive(true);
request.set_UseBinary(true);
request.set_Timeout(600000);
request.set_ReadWriteTimeout(600000);
ftpResponse = request.GetResponse();
response = ftpResponse;
reader = new System.IO.StreamReader(response.GetResponseStream());
if(reader)
{
readString = reader.ReadToEnd();
}
if(readString)
{
writer = new System.IO.StreamWriter(_destination);
writer.Write(readString);
writer.Flush();
writer.Close();
}
错误信息
操作已超时。
文件大小为 9kB。通过 Filezilla 下载它需要不到 1 秒。超时设置为 10 分钟。
是什么导致了这个消息? 关于如何调试的任何想法(我无法访问 FTP 服务器)。
更新: 在 C# 中,同样的代码运行良好。
FtpWebRequest ftpRequest;
var request = WebRequest.Create("ftp://server.com/folder/file.txt");
ftpRequest = (FtpWebRequest) request;
request.Credentials = new NetworkCredential("", "");
request.Method = "RETR";
ftpRequest.KeepAlive = false;
ftpRequest.UsePassive = true;
ftpRequest.UseBinary = true;
FtpWebResponse response = (FtpWebResponse)ftpRequest.GetResponse();
var reader = new StreamReader(response.GetResponseStream());
var result = "";
if(reader != null)
{
result = reader.ReadToEnd();
var writer = new StreamWriter(@"C:\temp\outfile.txt");
writer.Write(result);
writer.Flush();
writer.Close();
}
【问题讨论】:
-
您是否从批处理服务器运行 AX 代码,同时在本地计算机上执行 C# 代码?可能存在差异,例如无法解析“myserver.com”名称、关闭端口号 21/防火墙设置(以及“C:\temp\”路由可能不存在)。