executando métodos http usando o aplicativo windows em c #
Existem muitos sites que chamam um script no formulário de envio e passam em parâmetros usando HTTP POST ou GET, usando um depurador da web eu encontrei os parâmetros sendo passados. Agora eu quero fazer a mesma coisa através do meu aplicativo do Windows em c #. Como posso conseguir essa funcionalidade?
Eu estou usando atualmente HttpWebRequest e HttpWebResponse classe em c #. Mas é uma dor como eu tenho que escrever código explícito para cada página que eu tento carregar e trabalhar. Por exemplo, eu estou tentando passar o nome de usuário e senha para uma página php e tomar a resposta, que irá enviar um cookie e uma página em troca, com base em que eu identificar se o usuário tiver ou não logado.
HttpWebRequest loginreq = createreq("http://www.indyarocks.com/mobile/index.php");
String logintext = "username=" + TxtUsrname.Text + "&pass=" + TxtPasswd.Password + "&button.x=0&button.y=0";
loginreq.ContentLength = logintext.Length;
StreamWriter writerequest = new StreamWriter(loginreq.GetRequestStream());
writerequest.Write(logintext);
writerequest.Close();
HttpWebResponse getloginpageresponse = (HttpWebResponse)loginreq.GetResponse();
cookie = getloginpageresponse.Cookies[0];
BinaryFormatter bf1 = new BinaryFormatter();
Stream f1 = new FileStream("E:\\cookie.dat", FileMode.OpenOrCreate);
bf1.Serialize(f1, cookie);
f1.Close();
string nexturl = getloginpageresponse.Headers[HttpResponseHeader.Location];
StreamReader readresponse = new StreamReader(getloginpageresponse.GetResponseStream());
if (nexturl == "p_mprofile.php")
{
MessageBox.Show("Login Successful");
GrpMsg.IsEnabled = true;
}
else if (nexturl == "index.php?msg=1")
{
MessageBox.Show("Invalid Credentials Login again");
}
Esta é minha classe createreq
private HttpWebRequest createreq(string url)
{
HttpWebRequest temp = (HttpWebRequest)WebRequest.Create(url);
temp.Method = "POST";
temp.UserAgent = "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0; SLCC1; .NET CLR 2.0.50727; Media Center PC 5.0; .NET CLR 3.0.04506; .NET CLR 3.5.21022; FDM)";
temp.KeepAlive = true;
temp.ContentType = "application/x-www-form-urlencoded";
temp.CookieContainer = new CookieContainer();
temp.AllowAutoRedirect = false;
return temp;
}
Estou no caminho certo? Existe alguma maneira melhor de fazer isso?