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

简介:

     我们学习网络编程最熟悉的莫过于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,会找到如下的请求和响应的信息。

 

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(用户后台首页)。

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)
        {
            //网页内容填充webbrowser1控件
            string url = "http://localhost:59773/";

            //创建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";

            //上一次的返回结果
            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提交的内容
                var content = "username=" + username + "&password=" + password;

                //将content变为字节形式
                var bytes = Encoding.UTF8.GetBytes(content);

                var request = (HttpWebRequest)WebRequest.Create(url);

                //根据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("恭喜你,密码已经破解!一共花费:" + (i + 1) + "次,用户名为:" + username + ",密码为:" + password);
                        return;
                    }
                }

            }
            webBrowser2.DocumentText = "不好意思,未能破解";
        }
    }
}

 

第三步:我们现在要做的就是点击”暴力破解”,看看能不能给我枚举出来“肉鸡网站”的用户名和密码。

 

相关文章
|
14天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
14天前
|
程序员 开发者 Python
Python网络编程基础(Socket编程) 错误处理和异常处理的最佳实践
【4月更文挑战第11天】在网络编程中,错误处理和异常管理不仅是为了程序的健壮性,也是为了提供清晰的用户反馈以及优雅的故障恢复。在前面的章节中,我们讨论了如何使用`try-except`语句来处理网络错误。现在,我们将深入探讨错误处理和异常处理的最佳实践。
|
1天前
|
存储 网络协议 关系型数据库
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
|
4天前
|
存储 安全 网络安全
C#编程的安全性与加密技术
【4月更文挑战第21天】C#在.NET框架支持下,以其面向对象和高级特性成为安全软件开发的利器。本文探讨C#在安全加密领域的应用,包括使用System.Security.Cryptography库实现加密算法,利用SSL/TLS保障网络传输安全,进行身份验证,并强调编写安全代码的重要性。实际案例涵盖在线支付、企业应用和文件加密,展示了C#在应对安全挑战的同时,不断拓展其在该领域的潜力和未来前景。
|
4天前
|
程序员 C#
C#编程中的面向对象编程思想
【4月更文挑战第21天】本文探讨了C#中的面向对象编程,包括类、对象、封装、继承和多态。类是对象的抽象,定义属性和行为;对象是类的实例。封装隐藏内部细节,只暴露必要接口。继承允许类复用和扩展属性与行为,而多态使不同类的对象能通过相同接口调用方法。C#通过访问修饰符实现封装,使用虚方法和抽象方法实现多态。理解并应用这些概念,能提升代码的清晰度和可扩展性,助你成为更好的C#程序员。
|
5天前
|
IDE 程序员 C#
C#编程入门:从零开始的旅程
【4月更文挑战第20天】本文引导初学者入门C#编程,从环境搭建开始,推荐使用Visual Studio Community版作为IDE。接着,通过编写&quot;Hello, World!&quot;程序,介绍基本语法,包括数据类型、运算符和表达式。文章还涉及控制结构、函数和方法,以及面向对象编程概念。通过学习,读者将对C#有初步了解,并激发进一步探索编程世界的兴趣。
|
5天前
|
开发框架 .NET Java
探索 C#编程的奥秘与魅力
【4月更文挑战第20天】C#是微软开发的现代、面向对象的编程语言,以其简洁语法、强大功能和跨平台支持脱颖而出。它支持自动垃圾回收、泛型、委托、LINQ,并广泛应用于桌面、Web、移动和游戏开发。C#拥有活跃的开发者社区和丰富的资源,是Unity游戏开发的首选语言。随着.NET Core,C#可在多个操作系统上运行,持续创新,未来发展潜力巨大。
|
5天前
|
缓存 算法 测试技术
优化 C#编程性能的策略
【4月更文挑战第20天】优化C#性能策略包括:选择合适算法和数据结构,避免频繁对象创建,缓存常用数据,减少内存分配,使用异步编程,优化数据库操作(如合理查询和使用索引),利用多线程并行处理,精简代码,使用性能分析工具,硬件升级,以及进行性能测试。综合应用这些策略可提升程序性能和响应性。
|
8天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
10天前
|
SQL 安全 Java
Java安全编程:防范网络攻击与漏洞
【4月更文挑战第15天】本文强调了Java安全编程的重要性,包括提高系统安全性、降低维护成本和提升用户体验。针对网络攻击和漏洞,提出了防范措施:使用PreparedStatement防SQL注入,过滤和转义用户输入抵御XSS攻击,添加令牌对抗CSRF,限制文件上传类型和大小以防止恶意文件,避免原生序列化并确保数据完整性。及时更新和修复漏洞是关键。程序员应遵循安全编程规范,保障系统安全。