我不确定为什么会得到这个结果。我在 Linux 服务器上运行它。(这是我的小网站的共享虚拟主机帐户。)
文件分组如下:
并且Another Dir
里面有一个文件:
因此,我正在尝试使用以下代码检索服务器上不存在的目录中的badname
目录内容:1somelongdir1234567
try
{
FtpWebRequest ftpRequest = (FtpWebRequest)WebRequest.Create(
"ftp://server12.some-domain.com/public_html/1somelongdir1234567/badname");
ftpRequest.EnableSsl = true;
ftpRequest.Credentials = new NetworkCredential("user", "password");
ftpRequest.KeepAlive = true;
ftpRequest.Timeout = -1;
ftpRequest.Method = WebRequestMethods.Ftp.ListDirectoryDetails;
using (FtpWebResponse response1 = (FtpWebResponse)ftpRequest.GetResponse())
{
//*****BEGIN OF EDIT*****
Console.WriteLine(response1.StatusDescription);
Console.WriteLine(response1.StatusCode);
//*****END OF EDIT*****
using (StreamReader streamReader = new StreamReader(response1.GetResponseStream()))
{
List<string> arrList = new List<string>();
for (; ; )
{
string line = streamReader.ReadLine();
//I get to here, where `line` is null????
if (string.IsNullOrEmpty(line))
break;
arrList.Add(line);
//*****BEGIN OF EDIT*****
Console.WriteLine(line);
//*****END OF EDIT*****
}
}
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
如您所见,没有这样的文件夹badname
,但我没有抛出异常,而是ftpRequest.GetResponse()
成功然后streamReader.ReadLine()
返回null
,就像我在上面的代码中显示的那样。
更奇怪的是,如果我提供这样的实际目录:
FtpWebRequest ftpRequest = (FtpWebRequest)WebRequest.Create(
"ftp://server12.some-domain.com/public_html/1somelongdir1234567/Another%20Dir");
streamReader.ReadLine()
仍然null
返回。
有人可以解释为什么吗?
编辑:好的,伙计们,我更新了上面的代码以检索状态代码。不过我还是很疑惑。
首先,这是连接 URI 的三个值和我得到的响应/输出:
示例 1:
//Existing folder
"ftp://server12.some-domain.com/public_html/1somelongdir1234567"
输出:
150 Accepted data connection
OpeningData
drwxr-xr-x 3 username username 4096 Sep 5 05:51 .
drwxr-x--- 118 username 99 4096 Sep 5 05:54 ..
drwxr-xr-x 2 username username 4096 Sep 5 05:52 Another Dir
-rw-r--r-- 1 username username 11 Sep 5 05:51 test123.txt
示例 2:
//Another existing folder
"ftp://server12.some-domain.com/public_html/1somelongdir1234567/Another%20Dir"
输出:
150 Accepted data connection
OpeningData
示例 3:
//Nonexistent folder
"ftp://server12.some-domain.com/public_html/1somelongdir1234567/SomeBogusName"
输出:
150 Accepted data connection
OpeningData
那么为什么它给我的结果与我得到的 3 相同,例如 2?
至于它是什么 ftp 服务器,我无法在网络日志中看到它,也看不到它FtpWebRequest
本身。这是我能从中得到的Microsoft Network Monitor
:
欢迎使用 Pure-FTPd [privsep] [TLS] ----------..
220-您是允许的 50 个用户中的第 4 号... 220-当地时间现在是 13:14。服务器端口:21...
220-这是一个私人系统 - 不允许匿名登录..
220-此服务器也欢迎 IPv6 连接...
220 您将在 15 分钟不活动后断开连接...