想要使用C#(FtpWebResponse)从FTP读取文件列表,但它返回HTML

时间:2012-01-12 10:48:45

标签: c# ftp ftpwebrequest

我使用以下代码从FTP站点获取文件。它可以在我的计算机上运行,​​但是当我在另一台计算机上运行时它只返回HTML代码(我可以看到HTML是我通过浏览器访问FTP时的网页代码)。怎么了?

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;
}

enter image description here

4 个答案:

答案 0 :(得分:5)

可能是网络代理干扰吗?尝试使用以下内容绕过代理:

reqFTP.Proxy = GlobalProxySelection.GetEmptyWebProxy();

答案 1 :(得分:1)

这是通过HTTP代理使用FtpWebRequest的结果。文件列表使用HTML标记进行打印,HTML标记具有<A>超链接到列表中的各个文件。

如果您无法绕过代理,在我们的情况下,可以使用封闭的<PRE>元素从文件内容中删除该部分,将其加载到XmlDocument中,然后拉出文件列表通过.SelectNodes("//A/text()")

答案 2 :(得分:1)

我找到了解决方案:默认代理已意外启用

我现在必须使用配置文件专门禁用它:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
   <system.net>
    <defaultProxy enabled="false" useDefaultCredentials="true"/>
  </system.net>
</configuration>

实际上,它确实是一个.NET问题!

答案 3 :(得分:0)

FTP要求PassiveMode下载,上传...

相反,尝试使用:

reqFTP.UsePassive = true;