I have this method :
private string GetCheckResultFor(string url)
{
Stopwatch reveil = new Stopwatch();
reveil.Start();
HttpWebResponse response = null;
url = Regex.Replace(url, @"\s+", "");
if (!url.StartsWith("http") && !url.StartsWith("https")) url = "http://" + url;
string res = "";
try
{
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url);
request.Method = "GET";
response = (HttpWebResponse)request.GetResponse();
if (response.ResponseUri.ToString() == url) res = "No Action";
else res = "Redirect to " + response.ResponseUri.ToString();
}
catch (WebException e)
{
if (e.Status == WebExceptionStatus.ProtocolError)
{
response = (HttpWebResponse)e.Response;
res = "Errorcode: " + (int)response.StatusCode;
}
else
{
res = "Error: " + e.Status;
}
}
finally
{
if (response != null)
{
response.Close();
}
}
reveil.Stop();
Debug.WriteLine("For this url : " + url + " = " + reveil.ElapsedMilliseconds + " ms");
return res;
}
It takes between 200 and 700 ms. I know it depends on internet connection speed but I need to improve it because I only need the reponse url. I have Three possiblities :
- Reponse Url = request Url ==> No action
- Redirect to another url
- Request Error
So How can I edit this snippet to reduce method response time ?
request.Method = "GET";->request.Method = "HEAD";might save you some time and should still work. \$\endgroup\$