使用C#發(fā)送Http請(qǐng)求實(shí)現(xiàn)模擬登陸實(shí)例
模擬登陸的原理很簡(jiǎn)單,就是發(fā)送一個(gè)Http 請(qǐng)求服務(wù)器獲得響應(yīng),然后客戶端獲取到cookie即可實(shí)現(xiàn)模擬登陸,比如一些搶票軟件的原理無非也是這樣模擬客戶端的cookie 然后發(fā)送請(qǐng)求去搶票,然后12306 本文將演示如何用C# 來實(shí)現(xiàn)模擬登陸的,推薦一款工具Fiddler,這是一款監(jiān)聽http 請(qǐng)求的利器。廢話不多說,我就以博客園為例來實(shí)現(xiàn)模擬登陸。首先我登陸博客園 http://passport.cnblogs.com/login.aspx 輸入用戶名和密碼點(diǎn)登陸 就會(huì)看到Fiddler 上的相關(guān)信息:

Ok,我首先需要發(fā)送一個(gè)http 請(qǐng)求 ,這個(gè)請(qǐng)求時(shí)POST的方式,然后用戶名和密碼就是POST的數(shù)據(jù)。代碼如下:
static CookieContainer GetCookie(string postString, string postUrl)
{
CookieContainer cookie = new CookieContainer();
HttpWebRequest httpRequset = (HttpWebRequest)HttpWebRequest.Create(postUrl);//創(chuàng)建http 請(qǐng)求
httpRequset.CookieContainer = cookie;//設(shè)置cookie
httpRequset.Method = "POST";//POST 提交
httpRequset.KeepAlive = true;
httpRequset.UserAgent = "Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko";
httpRequset.Accept = "text/html, application/xhtml+xml, */*";
httpRequset.ContentType = "application/x-www-form-urlencoded";//以上信息在監(jiān)聽請(qǐng)求的時(shí)候都有的直接復(fù)制過來
byte[] bytes = System.Text.Encoding.UTF8.GetBytes(postString);
httpRequset.ContentLength = bytes.Length;
Stream stream = httpRequset.GetRequestStream();
stream.Write(bytes, 0, bytes.Length);
stream.Close();//以上是POST數(shù)據(jù)的寫入
HttpWebResponse httpResponse = (HttpWebResponse)httpRequset.GetResponse();//獲得 服務(wù)端響應(yīng)
return cookie;//拿到cookie
}
拿到cookie 之后我們就可以以用戶的什么去用戶的后臺(tái)或者其他的地方:
static string GetContent(CookieContainer cookie, string url)
{
string content;
HttpWebRequest httpRequest = (HttpWebRequest)HttpWebRequest.Create(url);
httpRequest.CookieContainer = cookie;
httpRequest.Referer = url;
httpRequest.UserAgent = "Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko";
httpRequest.Accept = "text/html, application/xhtml+xml, */*";
httpRequest.ContentType = "application/x-www-form-urlencoded";
httpRequest.Method = "GET";
HttpWebResponse httpResponse = (HttpWebResponse)httpRequest.GetResponse();
using (Stream responsestream = httpResponse.GetResponseStream())
{
using (StreamReader sr = new StreamReader(responsestream, System.Text.Encoding.UTF8))
{
content = sr.ReadToEnd();
}
}
return content;
}
OK 下面是調(diào)用 我寫的是一個(gè)控制臺(tái)程序:
static void Main(string[] args)
{
string loginstr = "{要post 的登陸數(shù)據(jù)包括用戶名和密碼}";
//從登陸的地址獲取cookie
CookieContainer cookie = GetCookie(loginstr, "http://passport.cnblogs.com/login.aspx");
//這個(gè)是進(jìn)入后臺(tái)地址
Console.WriteLine(GetContent(cookie, "http://i.cnblogs.com/EditPosts.aspx"));
Console.Read();
}
可以看到我已經(jīng)進(jìn)入了后臺(tái)了:

如果我是沒有登陸的情況下進(jìn)入這個(gè)地址是這樣的:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#短時(shí)間內(nèi)產(chǎn)生大量不重復(fù)的隨機(jī)數(shù)
在C#編程中,經(jīng)常會(huì)碰到產(chǎn)生隨機(jī)數(shù)的情況,并且是在短時(shí)間內(nèi)產(chǎn)生一組隨機(jī)數(shù)。如果這組隨機(jī)數(shù)中有大量重復(fù)的,則達(dá)不到我們的要求2013-02-02
C#匿名方法與Delegate類型轉(zhuǎn)換錯(cuò)誤分析
這篇文章主要介紹了C#匿名方法與Delegate類型轉(zhuǎn)換錯(cuò)誤,較為詳細(xì)的分析了C#匿名方法的用法及Delegate類型轉(zhuǎn)換錯(cuò)誤問題解決方法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-11-11
c# 實(shí)現(xiàn)網(wǎng)頁加載后將頁面截取為長(zhǎng)圖片
這篇文章主要介紹了c# 實(shí)現(xiàn)網(wǎng)頁加載后將頁面截取為長(zhǎng)圖片的方法,幫助大家更好的理解和學(xué)習(xí)c#,感興趣的朋友可以了解下2021-01-01

