C# 如何从 URL 下载文件_C# URL 文件下载实现指南

来源:这里教程网 时间:2026-02-21 17:30:27 作者:

在 C# 中从 URL 下载文件是一个常见需求,比如下载图片、文档或软件安装包。实现方式有多种,可根据具体场景选择合适的方法。以下是几种常用且可靠的实现方式。

使用 WebClient(简单快捷)

WebClient 是最简单的下载方式,适合快速实现文件下载功能。

说明: WebClient 封装了底层 HTTP 请求逻辑,使用 DownloadFile 方法可以直接将远程文件保存到本地。

示例代码:

using System.Net;<br><br>using (var client = new WebClient())<br>{<br>    client.DownloadFile("https://example.com/file.pdf", @"C:\Downloads\file.pdf");<br>}

优点是代码简洁,缺点是 WebClient 在 .NET Core/.NET 5+ 中已被标记为过时,推荐使用 HttpClient。

使用 HttpClient(推荐方式)

HttpClient 更现代、灵活,并支持异步操作,适合在新项目中使用。

说明: 通过 GetByteArrayAsync 或 GetStreamAsync 获取数据流,再写入本地文件。

示例代码(异步下载):

using System.Net.Http;<br>using System.IO;<br><br>using var httpClient = new HttpClient();<br>var data = await httpClient.GetByteArrayAsync("https://example.com/image.jpg");<br>await File.WriteAllBytesAsync(@"C:\Downloads\image.jpg", data);

如需处理大文件,避免内存溢出,可使用流式下载:

using var response = await httpClient.GetAsync("https://example.com/largefile.zip", HttpCompletionOption.ResponseHeadersRead);<br>using var stream = await response.Content.ReadAsStreamAsync();<br>using var fileStream = new FileStream(@"C:\Downloads\largefile.zip", FileMode.Create, FileAccess.Write);<br>await stream.CopyToAsync(fileStream);

这种方式能有效控制内存使用,适合下载大文件。

添加进度和错误处理

实际应用中需要关注下载进度和网络异常。

建议: 虽然 HttpClient 本身不直接提供下载进度,但可通过自定义流包装器来实现进度报告。同时应包裹 try-catch 处理网络中断、404 错误等情况。

基本异常处理示例:

try<br>{<br>    using var response = await httpClient.GetAsync(url);<br>    if (response.IsSuccessStatusCode)<br>    {<br>        using var stream = await response.Content.ReadAsStreamAsync();<br>        using var fileStream = new FileStream(filePath, FileMode.Create);<br>        await stream.CopyToAsync(fileStream);<br>    }<br>    else<br>    {<br>        Console.WriteLine($"下载失败:{response.StatusCode}");<br>    }<br>}<br>catch (HttpRequestException ex)<br>{<br>    Console.WriteLine($"网络错误:{ex.Message}");<br>}

设置请求头和超时时间

某些 URL 需要特定请求头(如 User-Agent)才能访问。

说明: 可通过 HttpClient 的 DefaultRequestHeaders 添加必要信息,避免被服务器拒绝。

示例:

httpClient.DefaultRequestHeaders.Add("User-Agent", "Mozilla/5.0");<br>httpClient.Timeout = TimeSpan.FromMinutes(10); // 设置超时

基本上就这些。根据项目环境选择 WebClient 或 HttpClient,优先使用后者。注意处理异常、大文件流式写入和请求头配置,就能稳定实现 URL 文件下载功能。

相关推荐