[转]12篇学通C#网络编程——第二首 HTTP应用编程(上)

正文转自:http://www.cnblogs.com/huangxincheng/archive/2012/01/09/2316745.html

  我们上学网络编程最熟悉的实际Http,好,我们虽起Http入手,首先我们肯定要询问一下http的基本原理和作为,对http的工作规律来

一定程度的掌握,对咱们下面的上都是产生好可怜襄的。

 

如出一辙: 工作方式

    ①:client和server建立保险的TCP连接。

    ②:然后client通过Socket向server发送http请求。

    ③:server端处理要,返回处理数量。

    ④:在http1.0惨遭,client与server之间的tcp连接立即断开。

       
 但在http1.1遭受,因为默认支持“tcp的增长连”,所以server端采用过才断开tcp连接的国策。

 

二: 特点

      ①:Http是任状态的,这个相信大家都知晓,我虽无多说了。

     
②:client通过以Http请求中之Header里追加有音讯来喻Server传送的中心的相干信息,比如:主体是呀类型,什么编码。

 

其三:Http请求和响应探究

     
 相信大家都掌握常用之乞求方式吧即是”Get”和“Post”,那么下面就来探索下Get和Post都起什么样有趣的地方,还是上图说话,首先

    我输入www.baidu.com,会找到如下的请求和响应的消息。

C# 1

 

1: “Request Header“: 

     第一行: Get / Http/1.1    

                 这里面有三单消息:①”Get”,表示要的模式。
②“/”,请求网站的一干二净目录。  ③”http/1.1″,这个就算是http的版本。

     第二行: Host

                 请求目标的网站,跟“/”并协同就是”www.baidu.com/”。

     第三行: Connection

               
 默看“keep-Alive“,这里就是文章开始所说之默认支持添加连。

     第四行: Cache-Control

                 这家伙跟缓存有关,其中max-age表示缓存的时日(s)。

     第五行:User-Agent

               
告诉serve我client的位置,一般由浏览器决定,比如:浏览器类型,版本等等。

     第六行:Accept

               
 以及后的Accept打头的还是标志client能够吸收的色及类别。

     最后一履行:Cookie

                 
 如果我们先是涂鸦为baidu请求时是从未cookie信息立即无异栏的,因为于浏览器下寻找不至于baidu相关的cookie,

                 
 当我们第二次刷新页面时,get请求虽会见找到当地的cookie并顺便给server。

 

2: “Response Header”:

     第一行: Http/1.1 200 OK

               
 这个量大家还知吧,200表示回去的状态码,OK则是描述性的状态码。

     第二行:Date

                表示服务器响应的时空。

     第三行: Server

                响应客户端的服务器。

     第四行:Content-Length

                表示服务器返回给客户端正文的许节约流长。

     第五行:Content-Type

                表示正文的项目。

     第七行:Expires

               
告诉client绝对的过时,比如2012.1.10,在是时空内client都好不用发送请求而直白打client的cache中落,

               
对js,css,image的苏存好有便宜,所以说用好了这特性对咱们http的性有非常要命的增援。

     第八行:Content-Encoding

               
文档类型的编码方式,服务器端采用gzip的花样开展了文档压缩,此时减多少了文档,利于下载,但是必须client端支持

                gzip的解码操作。

 

post的不二法门为是相同的,这里虽不说了,上面列举了这样多吗是期望大家能对Http的底细要有肯定程度之控。

 

季:应用场景

     我们于http上面的网络编程一般主要做少码业务。

     ①:爬数据,模拟登录,自动填写表单。

     ②:文件的上传和下载。

莫过.net对Http进行了酷好的包装,提供了HttpWebRequest和HttpWebResponse来为我们提供常用操作,如果大家对Http协议来个比较

清楚的认我思念类库里面的特性和道还是神马和浮云。

 

五 :案例

     
既然是上篇,就冲“模拟登录”的想做一个简约的“暴力破解”的有些程序,非常简单,呵呵。

   

先是步:
首先我们描绘少只action,一个login(登录页面),一个index(用户后台首页)。

C# 2😉

 1 namespace Test.Controllers
 2 {
 3     [HandleError]
 4     public class HomeController : Controller
 5     {
 6         public ActionResult Login()
 7         {
 8             return View();
 9         }
10 
11         [HttpPost]
12         public ActionResult Index(Model model)
13         {
14             if (model.UserName == "11" && model.Password == "11")
15                 return View(model);
16             else
17                 return RedirectToAction("Login");
18         }
19 
20         public ActionResult About()
21         {
22             return View();
23         }
24     }
25 
26     public class Model
27     {
28         public string UserName { get; set; }
29 
30         public string Password { get; set; }
31     }
32 }

C# 3😉

C# 4

 

好了,我们开辟fiddler,输入admin,admin,点击提交,看看都post些什么到server端了,方便我们后的仿登录,

这边的headC#信息相信大家要会看明白吧。

C# 5

亚步:我们新建一个winform的次第。

C# 6😉

 1 namespace Http  2 {  3     public partial class Form1 : Form  4     {  5         public Form1()  6         {  7             InitializeComponent();  8         }  9  10         private void Form1_Load(object sender, EventArgs e) 11         { 12             //网页内容填充webbrowser1控件 13             string url = "http://localhost:59773/"; 14  15             //创建http链接 16             var request = (HttpWebRequest)WebRequest.Create(url); 17  18             var response = (HttpWebResponse)request.GetResponse(); 19  20             Stream stream = response.GetResponseStream(); 21  22             StreamReader sr = new StreamReader(stream); 23  24             string content = sr.ReadToEnd(); 25  26             webBrowser1.DocumentText = content; 27         } 28  29         /// <summary> 30 /// 暴力破解 31 /// </summary> 32 /// <param name="sender"></param> 33 /// <param name="e"></param> 34         private void button1_Click(object sender, EventArgs e) 35         { 36             var url = "http://localhost:59773/Home/Index"; 37  38             //上一次的返回结果 39             string prev = string.Empty; 40  41             for (int i = 0; i < 100; i++) 42             { 43                 var username = new Random(DateTime.Now.Millisecond).Next(8, 19).ToString(); 44  45                 Thread.Sleep(2); 46  47                 var password = new Random(DateTime.Now.Millisecond).Next(8, 19).ToString(); 48  49                 //post提交的内容 50                 var content = "username=" + username + "&password=" + password; 51  52                 //将content变为字节形式 53                 var bytes = Encoding.UTF8.GetBytes(content); 54  55                 var request = (HttpWebRequest)WebRequest.Create(url); 56  57                 //根据fiddler中查看到的提交信息,我们也试着模拟追加此类信息然后提交 58                 request.Method = WebRequestMethods.Http.Post; 59                 request.Timeout = 1000 * 60; 60                 request.AllowAutoRedirect = true; 61                 request.ContentLength = bytes.Length; 62                 request.ContentType = "application/x-www-form-urlencoded"; 63  64  65                 //将content写入post请求中 66                 var stream = request.GetRequestStream(); 67                 stream.Write(bytes, 0, bytes.Length); 68                 stream.Close(); 69  70                 //写入成功,获取请求流 71                 var response = (HttpWebResponse)request.GetResponse(); 72  73                 var sr = new StreamReader(response.GetResponseStream()); 74  75                 var next = sr.ReadToEnd(); 76  77                 if (string.IsNullOrEmpty(prev)) 78                 { 79                     prev = next; 80                 } 81                 else 82                 { 83                     if (prev != next) 84                     { 85                         webBrowser2.DocumentText = next; 86                         MessageBox.Show("恭喜你,密码已经破解!一共花费:" + (i + 1) + "次,用户名为:" + username + ",密码为:" + password); 87                         return; 88                     } 89                 } 90  91             } 92             webBrowser2.DocumentText = "不好意思,未能破解"; 93         } 94     } 95 }

C# 7😉

C# 8

 

老三步:我们今天而做的尽管是点击”暴力破解”,看看能免能够于自己枚举出来“肉鸡网站”的用户称及密码。

C# 9

 

呵呵,现实中远不止这么简单,主要要想叫大家能针对HttpWebReqeust和HttpWebResponse有只了解。

 

 

 

分类:
C#网编程

 

相关文章