深入學(xué)習(xí)C#網(wǎng)絡(luò)編程之HTTP應(yīng)用編程(上)
我們學(xué)習(xí)網(wǎng)絡(luò)編程最熟悉的莫過于Http,好,我們就從Http入手,首先我們肯定要了解一下http的基本原理和作為,對http的工作原理有
一定程度的掌握,對我們下面的學(xué)習(xí)都是有很大幫助的。
一: 工作方式
①:client和server建立可靠的TCP連接。
②:然后client通過Socket向server發(fā)送http請求。
③:server端處理請求,返回處理數(shù)據(jù)。
④:在http1.0中,client與server之間的tcp連接立即斷開。
但在http1.1中,因為默認支持“tcp的長連接”,所以server端采用超時才斷開tcp連接的策略。
二: 特點
①:Http是無狀態(tài)的,這個相信大家都知道,我就不多說了。
②:client通過在Http請求中的Header里追加一些信息來告訴Server傳送的主體的相關(guān)信息,比如:主體是什么類型,什么編碼。
三:Http請求和響應(yīng)探究
相信大家都知道常用的請求方式也就是"Get"和“Post”,那么下面就來探究下Get和Post都有哪些好玩的地方,還是上圖說話,首先
我輸入www.baidu.com,會找到如下的請求和響應(yīng)的信息。

1: “Request Header“:
第一行: Get / Http/1.1
這里面有三個信息:①"Get",表示請求的模式。 ②“/",請求網(wǎng)站的根目錄。 ③"http/1.1",這個就是http的版本。
第二行: Host
請求目標(biāo)的網(wǎng)站,跟“/"并一起就是"www.baidu.com/"。
第三行: Connection
默認為“keep-Alive“,這里就是文章開頭所說的默認支持長連接。
第四行: Cache-Control
這玩意跟緩存有關(guān),其中max-age表示緩存的時間(s)。
第五行:User-Agent
告訴serve我client的身份,一般由瀏覽器決定,比如:瀏覽器類型,版本等等。
第六行:Accept
以及后面的Accept打頭的都是表明client能夠接收的種類和類型。
最后一行:Cookie
如果我們第一次向baidu請求時是沒有cookie信息這一欄的,因為在瀏覽器下找不到于baidu相關(guān)的cookie,
當(dāng)我們第二次刷新頁面時,get請求就會找到本地的cookie并附帶給server。
2: "Response Header":
第一行: Http/1.1 200 OK
這個估計大家都知道吧,200表示返回的狀態(tài)碼,OK則是描述性的狀態(tài)碼。
第二行:Date
表示服務(wù)器響應(yīng)的時間。
第三行: Server
響應(yīng)客戶端的服務(wù)器。
第四行:Content-Length
表示服務(wù)器返回給客戶端正文的字節(jié)流長度。
第五行:Content-Type
表示正文的類型。
第七行:Expires
告訴client絕對的過期時間,比如2012.1.10,在這個時間內(nèi)client都可以不用發(fā)送請求而直接從client的cache中獲取,
對js,css,image的緩存很有好處,所以說用好了這個屬性對我們http的性能有很大的幫助。
第八行:Content-Encoding
文檔類型的編碼方式,服務(wù)器端采用gzip的形式進行了文檔壓縮,此時減小了文檔,利于下載,但是必須client端支持
gzip的解碼操作。
post的方式也是一樣的,這里就不說了,上面列舉了這么多也是希望大家能夠?qū)ttp的細節(jié)要有一定程度的掌握。
四:應(yīng)用場景
我們在http上面的網(wǎng)絡(luò)編程一般主要做兩件事情。
①:爬數(shù)據(jù),模擬登錄,自動填表單。
②:文件的上傳和下載。
不過.net對Http進行了非常好的封裝,提供了HttpWebRequest和HttpWebResponse來給我們提供常用操作,如果大家對Http協(xié)議有個比較
清晰的認識我想類庫里面的屬性和方法都是神馬和浮云。
五 :案例
既然是上篇,就根據(jù)“模擬登錄”的思想做一個簡單的“暴力破解”的小程序,非常簡單,呵呵。
第一步: 首先我們寫兩個action,一個login(登錄頁面),一個index(用戶后臺首頁)。
namespace Test.Controllers
{
[HandleError]
public class HomeController : Controller
{
public ActionResult Login()
{
return View();
}
[HttpPost]
public ActionResult Index(Model model)
{
if (model.UserName == "11" && model.Password == "11")
return View(model);
else
return RedirectToAction("Login");
}
public ActionResult About()
{
return View();
}
}
public class Model
{
public string UserName { get; set; }
public string Password { get; set; }
}
}

好了,我們打開fiddler,輸入admin,admin,點擊提交,看看都post些什么到server端了,方便我們后面的模擬登錄,
這里的head信息相信大家還是能看懂吧。

第二步:我們新建一個winform的程序。
namespace Http
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
//網(wǎng)頁內(nèi)容填充webbrowser1控件
string url = "http://localhost:59773/";
//創(chuàng)建http鏈接
var request = (HttpWebRequest)WebRequest.Create(url);
var response = (HttpWebResponse)request.GetResponse();
Stream stream = response.GetResponseStream();
StreamReader sr = new StreamReader(stream);
string content = sr.ReadToEnd();
webBrowser1.DocumentText = content;
}
/// <summary>
/// 暴力破解
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
var url = "http://localhost:59773/Home/Index";
//上一次的返回結(jié)果
string prev = string.Empty;
for (int i = 0; i < 100; i++)
{
var username = new Random(DateTime.Now.Millisecond).Next(8, 19).ToString();
Thread.Sleep(2);
var password = new Random(DateTime.Now.Millisecond).Next(8, 19).ToString();
//post提交的內(nèi)容
var content = "username=" + username + "&password=" + password;
//將content變?yōu)樽止?jié)形式
var bytes = Encoding.UTF8.GetBytes(content);
var request = (HttpWebRequest)WebRequest.Create(url);
//根據(jù)fiddler中查看到的提交信息,我們也試著模擬追加此類信息然后提交
request.Method = WebRequestMethods.Http.Post;
request.Timeout = 1000 * 60;
request.AllowAutoRedirect = true;
request.ContentLength = bytes.Length;
request.ContentType = "application/x-www-form-urlencoded";
//將content寫入post請求中
var stream = request.GetRequestStream();
stream.Write(bytes, 0, bytes.Length);
stream.Close();
//寫入成功,獲取請求流
var response = (HttpWebResponse)request.GetResponse();
var sr = new StreamReader(response.GetResponseStream());
var next = sr.ReadToEnd();
if (string.IsNullOrEmpty(prev))
{
prev = next;
}
else
{
if (prev != next)
{
webBrowser2.DocumentText = next;
MessageBox.Show("恭喜你,密碼已經(jīng)破解!一共花費:" + (i + 1) + "次,用戶名為:" + username + ",密碼為:" + password);
return;
}
}
}
webBrowser2.DocumentText = "不好意思,未能破解";
}
}
}

第三步:我們現(xiàn)在要做的就是點擊”暴力破解”,看看能不能給我枚舉出來“肉雞網(wǎng)站”的用戶名和密碼。

呵呵,現(xiàn)實中遠不止這么簡單,主要還是想讓大家能夠?qū)ttpWebReqeust和HttpWebResponse有個了解。
以上就是深入學(xué)習(xí)C#網(wǎng)絡(luò)編程之HTTP應(yīng)用編程(上)的詳細內(nèi)容,更多關(guān)于C#網(wǎng)絡(luò)編程之HTTP應(yīng)用編程的資料請關(guān)注腳本之家其它相關(guān)文章!
- C# TcpClient網(wǎng)絡(luò)編程傳輸文件的示例
- C# 網(wǎng)絡(luò)編程之UDP
- c# 網(wǎng)絡(luò)編程之tcp
- c# 網(wǎng)絡(luò)編程之http
- 深入學(xué)習(xí)C#網(wǎng)絡(luò)編程之HTTP應(yīng)用編程(下)
- 淺談C#網(wǎng)絡(luò)編程詳解篇
- 詳解C# 網(wǎng)絡(luò)編程系列:實現(xiàn)類似QQ的即時通信程序
- 總結(jié)C#網(wǎng)絡(luò)編程中對于Cookie的設(shè)定要點
- C# Socket網(wǎng)絡(luò)編程實例
- C#網(wǎng)絡(luò)編程基礎(chǔ)之進程和線程詳解
- c# socket網(wǎng)絡(luò)編程接收發(fā)送數(shù)據(jù)示例代碼
- C#開發(fā)之Socket網(wǎng)絡(luò)編程TCP/IP層次模型、端口及報文等探討
- C#網(wǎng)絡(luò)編程中常用特性介紹
相關(guān)文章
支持多類型數(shù)據(jù)庫的c#數(shù)據(jù)庫模型示例
本文為大家提供一個c#數(shù)據(jù)庫訪問模型,支持多類型數(shù)據(jù)庫,簡單抽取數(shù)據(jù)庫訪問函數(shù),大家參考使用吧2014-01-01
C#數(shù)據(jù)結(jié)構(gòu)之單鏈表(LinkList)實例詳解
這篇文章主要介紹了C#數(shù)據(jù)結(jié)構(gòu)之單鏈表(LinkList)實現(xiàn)方法,結(jié)合實例形式較為詳細的分析了單鏈表的原理、定義與C#具體實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
淺談static a[n*m]={0};中static的作用
下面小編就為大家?guī)硪黄獪\談static a[n*m]={0};中static的作用。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03

