我在IIS服务器上使用“网站”面板。 我想使用ftp上传文件
我使用了这段代码:
try
{
WebClient webClient = new WebClient();
OpenFileDialog fd = new OpenFileDialog();
fd.ShowDialog();
MessageBox.Show(fd.FileName);
webClient.UploadFileTaskAsync(new Uri("ftp://" + "username" + ":" +"pass" +"@" + "address/" + "name.ext"), fd.FileName);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
此代码运行时没有错误。当我使用网站面板的文件管理器时,一个文件创建了“Name.ext”,但是这个文件大小是0 KB。为什么?我的问题是什么?
我确信Windows防火墙允许我这样做。
更新:我正在使用UploadFileTask和UploadFile(非同步),但结果与async相同:(
答案 0 :(得分:3)
您的异常可能会被从WebClient.UploadFileTaskAsync
返回的未经授权的任务中吞没。您应await
执行任务,这样catch
块会检测到潜在的异常,因为它将传播到等待的代码行:
public async Task UploadFileByFtpAsync()
{
try
{
WebClient webClient = new WebClient();
OpenFileDialog fd = new OpenFileDialog();
fd.ShowDialog();
MessageBox.Show(fd.FileName);
Task<byte[]> response = await webClient.UploadFileTaskAsync(new Uri("ftp://" + "username" + ":" +"pass" +"@" + "address/" + "name.ext"), fd.FileName);
// You might want to validate the response status code is valid here
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
// Do useful exception handling here
}
}
修改强>
正如我在评论中所说,检查response
变量,它包含可能失败的上传尝试的响应。
修改2
似乎问题在于web / ftp请求的KeepAlive
属性。 The underlying connection was closed: The server committed a protocol violation. FTP和here
答案 1 :(得分:2)
我的第一个想法是你没有等待异步调用,因此运行此代码的任何进程或线程可能会在UploadFileTaskAsync
调用实际完成之前结束。
尝试将try块的最后一次调用更改为
await webClient.UploadFileTaskAsync(new Uri("ftp://" + "username" + ":" +"pass" +"@" + "address/" + "name.ext"), fd.FileName);
您可能还想检查通话的返回值:
var result = await webClient.UploadFileTaskAsync(new Uri("ftp://" + "username" + ":" +"pass" +"@" + "address/" + "name.ext"), fd.FileName);
结果对象是来自服务器的响应的byte[]
。
答案 2 :(得分:1)
我建议使用本机FtpWebRequest类来上传文件。
try
{
OpenFileDialog fd = new OpenFileDialog();
fd.ShowDialog();
MessageBox.Show(fd.FileName);
FtpWebRequest request = (FtpWebRequest)FtpWebRequest.Create("ftp://address/" + fd.FileName);
request.Method = WebRequestMethods.Ftp.UploadFile;
request.Credentials = new NetworkCredential("username", "pass");
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = false;
FileStream stream = File.OpenRead(fd.FileName);
byte[] buffer = new byte[stream.Length];
stream.Read(buffer, 0, buffer.Length);
stream.Close();
Stream reqStream = request.GetRequestStream();
reqStream.Write(buffer, 0, buffer.Length);
reqStream.Close();
}
catch (Exception ex)
{ MessageBox.Show(ex.Message);
}