如何在我的应用程序中实现从 HTTP 下载大文件(~500MB)?我想支持自动恢复/重试,这样当连接断开时,我的应用程序可以尝试重新连接以获取文件并避免重新下载下载的部分,如果可能的话(我知道,这也取决于服务器)。
这类似于下载管理器和某些浏览器中的行为。
C#
您可以通过以下两种方式之一从头开始从 Web 服务器下载:
使用 System.Net 中的高级 API,例如HttpWebRequest
、HttpWebResponse
、FtpWebRequest
和其他类。
使用 System.Net.Sockets 中的低级 API,例如TcpClient
和TcpListener
Socket 类。
使用第一种方法的优点是您通常不必担心低级管道,例如准备和解释 HTTP 标头以及处理代理、身份验证、缓存等。高级类为您执行此操作,因此我更喜欢这种方法。
使用第一种方法,准备从 url 下载文件的 HTTP 请求的典型代码如下所示:
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(Url);
if (UseProxy)
{
request.Proxy = new WebProxy(ProxyServer + ":" + ProxyPort.ToString());
if (ProxyUsername.Length > 0)
request.Proxy.Credentials = new NetworkCredential(ProxyUsername, ProxyPassword);
}
//HttpWebRequest hrequest = (HttpWebRequest)request;
//hrequest.AddRange(BytesRead); ::TODO: Work on this
if (BytesRead > 0) request.AddRange(BytesRead);
WebResponse response = request.GetResponse();
//result.MimeType = res.ContentType;
//result.LastModified = response.LastModified;
if (!resuming)//(Size == 0)
{
//resuming = false;
Size = (int)response.ContentLength;
SizeInKB = (int)Size / 1024;
}
acceptRanges = String.Compare(response.Headers["Accept-Ranges"], "bytes", true) == 0;
//create network stream
ns = response.GetResponseStream();
在上述代码的末尾,您会得到一个网络流对象,然后您可以使用它来读取远程文件的字节,就像您正在读取任何其他流对象一样。现在,远程 url 是否支持通过允许您从任意位置读取来恢复部分下载是由如上所示的“Accept-Ranges” HTTP 标头确定的。如果此值设置为“字节”以外的任何值,则不支持此功能。
事实上,这段代码是我试图在 C# 中实现的更大的开源下载管理器的一部分。您可以参考这个应用程序,看看是否有什么对您有帮助: http: //scavenger.codeplex.com/
有一个开源的.Net http文件下载器,支持自动恢复/重试(如果服务器支持的话),看起来正是你需要的,可以尝试使用它: