欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C#教程

當前位置:主頁 > 軟件編程 > C#教程 >

使用C#發(fā)送Http請求實現(xiàn)模擬登陸實例

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C#教程|點擊: 次

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

Ok,我首先需要發(fā)送一個http 請求 ,這個請求時POST的方式,然后用戶名和密碼就是POST的數(shù)據(jù)。代碼如下:

static CookieContainer GetCookie(string postString, string postUrl)
 {
 CookieContainer cookie = new CookieContainer();
 
 HttpWebRequest httpRequset = (HttpWebRequest)HttpWebRequest.Create(postUrl);//創(chuàng)建http 請求
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)聽請求的時候都有的直接復(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 之后我們就可以以用戶的什么去用戶的后臺或者其他的地方:

 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)用 我寫的是一個控制臺程序:

static void Main(string[] args)
{
string loginstr = "{要post 的登陸數(shù)據(jù)包括用戶名和密碼}";
//從登陸的地址獲取cookie
CookieContainer cookie = GetCookie(loginstr, "http://passport.cnblogs.com/login.aspx");
 //這個是進入后臺地址
 Console.WriteLine(GetContent(cookie, "http://i.cnblogs.com/EditPosts.aspx"));
 Console.Read();
}

可以看到我已經(jīng)進入了后臺了:

如果我是沒有登陸的情況下進入這個地址是這樣的:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。

上一篇:WPF換膚設(shè)計原理淺析

欄    目:C#教程

下一篇:C#操作XML通用方法匯總

本文標題:使用C#發(fā)送Http請求實現(xiàn)模擬登陸實例

本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6229.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有