我有几个 URL 存储在一个文本文件中,每个 URL 都是一个指向 Facebook 表情符号的链接,例如https://www.facebook.com/images/emoji.php/v5/u75/1/16/1f618.png
我正在尝试下载这些图像并将它们存储在我的磁盘上。我正在将 WebClient 与 DownloadFileAsync 一起使用,例如
using (var client = new WebClient())
{
client.DownloadFileAsync(imgURL, imgName);
}
我的问题是即使 URL 的数量很小,比如 10 个,有些图像下载正常,有些给我一个文件损坏错误。所以我想我需要等待文件下载到最后并添加 DownloadFileCompleted 事件,像这样
using System;
using System.ComponentModel;
using System.Collections.Generic;
using System.Linq;
using System.Net;
class Program
{
static Queue<string> q;
static void Main(string[] args)
{
q = new Queue<string>(new[] {
"https://www.facebook.com/images/emoji.php/v5/u51/1/16/1f603.png",
"https://www.facebook.com/images/emoji.php/v5/ud2/1/16/1f604.png",
"https://www.facebook.com/images/emoji.php/v5/ud4/1/16/1f606.png",
"https://www.facebook.com/images/emoji.php/v5/u57/1/16/1f609.png",
"https://www.facebook.com/images/emoji.php/v5/u7f/1/16/1f60a.png",
"https://www.facebook.com/images/emoji.php/v5/ufb/1/16/263a.png",
"https://www.facebook.com/images/emoji.php/v5/u81/1/16/1f60c.png",
"https://www.facebook.com/images/emoji.php/v5/u2/1/16/1f60d.png",
"https://www.facebook.com/images/emoji.php/v5/u75/1/16/1f618.png",
"https://www.facebook.com/images/emoji.php/v5/u1e/1/16/1f61a.png"
});
DownloadItem();
Console.WriteLine("Hit return after 'finished' has appeared...");
Console.ReadLine();
}
private static void DownloadItem()
{
if (q.Any())
{
var uri = new Uri(q.Dequeue());
var file = uri.Segments.Last();
var webClient = new WebClient();
webClient.DownloadFileCompleted += DownloadFileCompleted;
webClient.DownloadFileAsync(uri, file);
}
else
{
Console.WriteLine("finished");
}
}
private static void DownloadFileCompleted(object sender, AsyncCompletedEventArgs e)
{
DownloadItem();
}
}
它没有帮助,我决定仔细查看损坏的文件。
看起来损坏的文件实际上不是图像文件,而是 HTML 页面,这些页面要么有一些重定向到图像的 JavaScript 代码,要么是完整的 HTML 页面,表明我的浏览器不受支持。
所以我的问题是,我实际上如何等待图像文件已完全加载并准备好下载?
编辑我也试图删除该using
声明,但这也无济于事。