当他们有特殊字符时,我在FTP中管理文件时遇到问题.例如带有ó或similars的文件名.
我举个例子.首先,我想列出并处理FTP中文件夹的每个文件:
ftp = CType(FtpWebRequest.Create(sFtpPath),FtpWebRequest) ftp.Method = WebRequestMethods.Ftp.ListDirectory reader = New StreamReader(ftp.GetResponse().GetResponseStream()) files = reader.ReadToEnd.Split(New String() {NewLine},StringSplitOptions.RemoveEmptyEntries) reader.Close()
但是当文件包含特殊字符时,这会给我带来问题,因为我对该文件的字符串在FTP上“不存在”,例如:
For Each sFich As String In files ftp = CType(FtpWebRequest.Create(sFtpPath & "/" & sFich),FtpWebRequest) ftp.Method = WebRequestMethods.Ftp.DownloadFile reader = New StreamReader(ftp.GetResponse().GetResponseStream()) '... Next
例如,FTP上的文件EXAMPLE_aró,这里检索为EXAMPLE_ar□,所以当我尝试下载文件时,它说不存在.
我该怎么处理?
解决方法
从
this question的答案判断,您可能需要指定用于获取文件列表的StreamReader的编码.默认值为UTF8,您可以使用其他编码,如下所示:
reader = New StreamReader(ftp.GetResponse().GetResponseStream(),System.Text.Encoding.Unicode)
当我遇到编码问题时,我通常会将乱码复制并粘贴到一个编辑器中,该编辑器可以显示字符的十六进制值,然后从中找出编码.
上面的字符串包含字符00F3.您的个人资料显示您在西班牙.把这两个放在一起,在谷歌的帮助下我猜测FTP服务器正在使用西班牙语的EBCDIC,这是代码页1145.所以试试这个:
reader = New StreamReader(ftp.GetResponse().GetResponseStream(),System.Text.Encoding.GetEncoding(1145))
编辑:结果F3是大多数编码中的急性编码,包括扩展的ASCII,我的搜索中出现了EBCDIC.