Respostas:
Experimente WebClient.DownloadFileAsync()
. Você pode ligar CancelAsync()
por cronômetro com seu próprio tempo limite.
var taskDownload = client.DownloadFileTaskAsync(new Uri("http://localhost/folder"),"filename")
e entãotaskDownload.Wait(TimeSpan.FromSeconds(5));
Minha resposta vem daqui
Você pode criar uma classe derivada, que definirá a propriedade de tempo limite da WebRequest
classe base :
using System;
using System.Net;
public class WebDownload : WebClient
{
/// <summary>
/// Time in milliseconds
/// </summary>
public int Timeout { get; set; }
public WebDownload() : this(60000) { }
public WebDownload(int timeout)
{
this.Timeout = timeout;
}
protected override WebRequest GetWebRequest(Uri address)
{
var request = base.GetWebRequest(address);
if (request != null)
{
request.Timeout = this.Timeout;
}
return request;
}
}
e você pode usá-lo como a classe WebClient base.
request.Timeout
. Mensagem de erro 'System.Net.WebRequest' does not contain a definition for 'Timeout' and no extension method 'Timeout' accepting a first argument of type 'System.Net.WebRequest' could be found (are you missing a using directive or an assembly reference?)
, o que estou perdendo?
using
diretivas que são usadas por este trecho de código.
Supondo que você queira fazer isso de forma síncrona, usando o método WebClient.OpenRead (...) e definindo o tempo limite no Stream que ele retorna, você obterá o resultado desejado:
using (var webClient = new WebClient())
using (var stream = webClient.OpenRead(streamingUri))
{
if (stream != null)
{
stream.ReadTimeout = Timeout.Infinite;
using (var reader = new StreamReader(stream, Encoding.UTF8, false))
{
string line;
while ((line = reader.ReadLine()) != null)
{
if (line != String.Empty)
{
Console.WriteLine("Count {0}", count++);
}
Console.WriteLine(line);
}
}
}
}
Derivar de WebClient e substituir GetWebRequest (...) para definir o tempo limite sugerido por @Beniamin não funcionou para mim, mas funcionou.
stream.ReadTimeout
maior do que realmente demorou para executar a solicitação