我使用下面的代码从FTP站点获取文件。它在我的电脑上工作,但当我在另一台电脑上运行它时,它只返回HTML代码(当我通过浏览器访问FTP时,我可以看到HTML是网页的代码)。怎么了?
public String GetFilesAsString(string folder,string fileExtension)
{
StringBuilder result = new StringBuilder();
FtpWebRequest reqFTP;
try
{
String ftpserver = ftp + folder+"/";
reqFTP = (FtpWebRequest)FtpWebRequest.Create(new Uri(ftpserver));
reqFTP.UsePassive = false;
reqFTP.UseBinary = true;
reqFTP.Credentials = new NetworkCredential(username, password);
reqFTP.Method = WebRequestMethods.Ftp.ListDirectory;
FtpWebResponse response = (FtpWebResponse)reqFTP.GetResponse();
StreamReader reader = new StreamReader(response.GetResponseStream(), System.Text.Encoding.UTF8);
string line = "";
while (reader.Peek()>-1)
{
line = reader.ReadLine();
Console.WriteLine(line);//**********HTML was wrote out here*************
}
if (result.ToString().LastIndexOf('\n') >= 0)
result.Remove(result.ToString().LastIndexOf('\n'), 1);
reader.Close();
response.Close();
return result.ToString();
}
catch (Exception ex)
{
}
return null;
}

发布于 2012-01-12 18:56:47
会不会是web代理干扰?尝试使用以下方法绕过代理:
reqFTP.Proxy = GlobalProxySelection.GetEmptyWebProxy();发布于 2012-05-21 19:03:06
这是通过HTTP代理使用FtpWebRequest的结果。文件清单使用HTML标记打印得非常漂亮,这些标记有指向清单中各个文件的<A>超链接。
如果不能绕过代理,在我们的示例中,可以从封闭的<PRE>元素中抓取包含文件内容的部分,将其加载到XmlDocument中,然后通过.SelectNodes("//A/text()")拉出文件列表
发布于 2015-04-17 08:19:06
我找到了解决方案:默认代理被意外启用
我现在必须专门使用一个配置文件禁用它:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.net>
<defaultProxy enabled="false" useDefaultCredentials="true"/>
</system.net>
</configuration>事实上,这真的是一个.NET问题!
https://stackoverflow.com/questions/8833793
复制相似问题