¿Cómo descargaría todo tipo de archivos desde un sitio web?
Tengo el siguiente código en una nueva clase:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using HtmlAgilityPack;
using System.IO;
using System.Text.RegularExpressions;
using System.Xml.Linq;
using System.Net;
using System.Web;
using System.Threading;
using DannyGeneral;
using GatherLinks;
namespace GatherLinks
{
class RetrieveWebContent
{
HtmlAgilityPack.HtmlDocument doc;
string imgg;
int images;
public RetrieveWebContent()
{
images = 0;
}
public List<string> retrieveImages(string address)
{
try
{
doc = new HtmlAgilityPack.HtmlDocument();
System.Net.WebClient wc = new System.Net.WebClient();
List<string> imgList = new List<string>();
doc.Load(wc.OpenRead(address));
HtmlNodeCollection imgs = doc.DocumentNode.SelectNodes("//img[@src]");
if (imgs == null) return new List<string>();
foreach (HtmlNode img in imgs)
{
if (img.Attributes["src"] == null)
continue;
HtmlAttribute src = img.Attributes["src"];
imgList.Add(src.Value);
if (src.Value.StartsWith("http") || src.Value.StartsWith("https") || src.Value.StartsWith("www"))
{
images++;
string[] arr = src.Value.Split('/');
imgg = arr[arr.Length - 1];
wc.DownloadFile(src.Value, @"d:\MyImages\" + imgg);
}
}
return imgList;
}
catch
{
Logger.Write("There Was Problem Downloading The Image: " + imgg);
return null;
}
}
}
}
El código anterior es parte de mi WebCrawler. Este código solo descargará archivos de imagen de un sitio web.
Por ejemplo, tengo este sitio:http://web.archive.org/web/20131216195236/http://open-hardware-monitor.googlecode.com/svn/trunk/
Contenido en el sitio mencionado es un archivo llamadoApp
. Si hago clic derecho ysave as
, entonces veo que es un archivo de configuración. Si hago clic en elHardware/
enlace, entonces veo muchos archivos * .CS.
¿Cómo puedo hacer y / o actualizar mi código para que descargue todo tipo de archivos en lugar de solo descargar imágenes?