wykonywanie metod http przy użyciu aplikacji Windows w c #
Istnieje wiele witryn, które wywołują skrypt na formularzu, przesyłają i przekazują parametry przy użyciu HTTP POST lub GET, używając debugera internetowego, znalazłem przekazane parametry. Teraz chcę zrobić to samo za pośrednictwem mojej aplikacji Windows w C #. Jak mogę osiągnąć taką funkcjonalność?
Obecnie używam klasy HttpWebRequest i HttpWebResponse w C #. Ale to ból, ponieważ muszę napisać wyraźny kod dla każdej strony, którą próbuję załadować i pracować. Na przykład próbuję przekazać nazwę użytkownika i hasło na stronę php i odebrać odpowiedź, która wyśle plik cookie i stronę w zamian, na podstawie której zidentyfikuję, czy użytkownik się zalogował, czy nie.
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");
}
To jest moja klasa 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;
}
Czy jestem na dobrej drodze? Czy jest jakiś lepszy sposób na to?