WebRequest następująco przekierowań bez interwencji użytkownika, więc jeśli używasz przekierowania 301/302 kody stanu następnie dodaje zadziała
WebRequest request = WebRequest.Create(destination);
WebResponse response = request.GetResponse();
Console.WriteLine(response.ResponseUri);
Jeśli przekierowania są tworzone przy użyciu JavaScript lub http-equiv meta tagi wtedy” Robię to, aby przeanalizować stronę i poszukać. Pakiet agility HTML jest prawdopodobnie najlepszym sposobem na zrobienie tego.
Aby wziąć to trochę dalej po to klasa, która będzie ręcznie rozwiązać główne kody stanu przekierowanie HTTP, budując historię jak to idzie
/// <summary>
/// Digs through HTTP redirects until a non-redirected URL is found.
/// </summary>
public class Digger
{
/// <summary>
/// Initializes a new instance of the <see cref="Digger"/> class.
/// </summary>
public Digger() : this(20)
{
}
/// <summary>
/// Initializes a new instance of the <see cref="Digger"/> class.
/// </summary>
/// <param name="maximumDepth">The maximum depth of redirects to parse.</param>
public Digger(int maximumDepth)
{
this.MaximumDepth = maximumDepth;
}
/// <summary>
/// Gets the maximum depth of redirects to parse.
/// </summary>
/// <value>The maximum depth of redirects to parse.</value>
public int MaximumDepth
{
get;
private set;
}
/// <summary>
/// Resolves any redirects at the specified URI.
/// </summary>
/// <param name="destination">The initial URI.</param>
/// <returns>The URI after resolving any HTTP redirects.</returns>
public Uri Resolve(Uri destination)
{
List<Uri> redirectHistory = new List<Uri>();
return this.Resolve(destination, redirectHistory);
}
/// <summary>
/// Resolves any redirects at the specified URI.
/// </summary>
/// <param name="destination">The initial URI.</param>
/// <param name="redirectHistory">A collection of <see cref="Uri"/> objects representing the redirect history.</param>
/// <returns>The URI after resolving any HTTP redirects.</returns>
public Uri Resolve(Uri destination, ICollection<Uri> redirectHistory)
{
redirectHistory.Add(destination);
return this.Resolve(destination, this.MaximumDepth, redirectHistory);
}
/// <summary>
/// Resolves any redirects at the specified URI.
/// </summary>
/// <param name="destination">The initial URI.</param>
/// <param name="hopsLeft">The maximum number of redirects left to follow.</param>
/// <param name="redirectHistory">A collection of <see cref="Uri"/> objects representing the redirect history.</param>
/// <returns>The URI after resolving any HTTP redirects.</returns>
private Uri Resolve(Uri destination, int hopsLeft, ICollection<Uri> redirectHistory)
{
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(destination);
request.AllowAutoRedirect = false;
request.Method = "HEAD";
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
Uri resolvedUri;
if (response.StatusCode == HttpStatusCode.Redirect ||
response.StatusCode == HttpStatusCode.Moved ||
response.StatusCode == HttpStatusCode.MovedPermanently)
{
if (hopsLeft > 0)
{
Uri redirectUri = new Uri(response.GetResponseHeader("Location"));
if (redirectHistory.Contains(redirectUri))
{
throw new Exception("Recursive redirection found");
}
redirectHistory.Add(redirectUri);
resolvedUri = this.Resolve(redirectUri, hopsLeft - 1, redirectHistory);
}
else
{
throw new Exception("Maximum redirect depth reached");
}
}
else
{
resolvedUri = response.ResponseUri;
}
return resolvedUri;
}
}
Zależy jak działa przekierowanie. Po stronie serwera? Strona klienta (tj. JS)? Spróbuj pobrać adres URL z dowolnymi opakowaniami http C# i postępuj zgodnie z dowolnymi 301s/302. Jeśli masz szczęście, może być nawet biblioteka, która zrobi to za Ciebie. Co się stanie, jeśli B przekieruje do C? Czy chcesz przechowywać B lub C? Jak daleko zajmiesz się przekierowaniami? Co jeśli C przekierowuje do B? Upewnij się, że unikasz nieskończonych pętli przekierowania, śledząc odwiedzone adresy lub ustawiając limit przekierowania (co, jak sądzę, obsługuje ten problem Firefox/Chrome). –
Przykład po stronie serwera byłby w porządku ... to tylko narzędzie do wyodrębniania danych (tj. Końcowego adresu URL), więc nie musi być fantazyjne ... można to zrobić w jakikolwiek sposób! "A" zawsze przekieruje do "B" i nie ma więcej przekierowania, które mogłoby nastąpić dalej, co jest ustalonym faktem. –
Kod po stronie klienta też nie zaszkodzi ... Zakładam, że aplikacja do wygrywania formularzy z instancją IE w środku powinna wykonać zadanie ... po prostu nie jestem pewien –