为什么FTPWebRequest或WebRequest一般都不接受/../路径?

我试图从ftp Web服务器自动执行一些上传/下载任务。 当我通过客户端或通过Firefox连接到服务器时,为了进入我的目录,我必须指定这样的路径:

ftp://ftpserver.com/../AB00000/incoming/files 

如果我尝试访问此内容:

 ftp://ftpserver.com/AB00000/incoming/files 

服务器抛出该目录不存在的错误。 那么,问题是:

我试图用第一个ftp地址创建一个FTPWebRequest,但它总是解析出“/../”部分然后我的服务器说该路径不存在。

我试过这些:

  Uri target = new Uri("ftp://ftpserver.com/../AB00000/incoming/files"); FtpWebRequest request = (FtpWebRequest)WebReqeuest.Create(target); 

 string target = "ftp://ftpserver.com/../AB00000/incoming/files"; FtpWebRequest request = (FtpWebRequest)WebRequest.Create(target); 

在第一位,当实例化Uri对象时,路径已经不正确,在第二位,它在WebRequest.Create方法之后。 有什么想法正在发生什么?

编辑:

另外,由于我发布了这个,我尝试使用no parse选项创建URI。 我也尝试过这样的事情:

 string ftpserver = "ftp://ftpserver.com/../"; string path = "12345/01/01/file.toupload"; Uri = new Uri(ftpserver, path, true); 

它总是解析根部分(“/../”)。

尝试使用类似的东西逃避..

 Uri target = new Uri("ftp://ftpserver.com/%2E%2E/AB00000/incoming/files"); 

根据我在本次讨论中发现的博客 ,这是有效的。

不太确定,但可能出于安全原因,因为允许“/../”URI可能会让人们在任何服务器的文件系统上自由导航。

此外,官方URI RFC指出,在解析URI时,执行的步骤之一实际上是删除“/../”段,因此它不是C#库中的问题,而是常规URI行为。

您是否尝试使用@符号?

 Uri target = new Uri(@"ftp://ftpserver.com/../AB00000/incoming/files"); FtpWebRequest request = (FtpWebRequest)WebReqeuest.Create(target);