zoukankan      html  css  js  c++  java
  • 初识HTTP协议请求与响应报文

                HTTP相信大家都知道这个词,我们也都知道它是要干嘛的,以前的我也一直只是知道它就是基于TCP/IP协议为浏览器和服务器提供的一个通信协议标准,可以是GET、POST方式,可以通过telnet的方法 来发送一个HTTP请求并得到返回的内容,默认端口是80啊等等。最近也不知道出于什么原因,突然就想了解它的内部协议构造了,网上找了点资料,并动手去查看研究研究它。

          概念啥的就不去理会了;既然HTTP是基于TCP/IP的那么我们先看看TCP/IP协议又是怎么回事?

          在OSI的七层模型中,TCP是在传输层中,而IP则在网络层。而在OSI的各层中层与层之间是相互独立又相互依靠的,上层依赖于下层,下层又为上层提供服务,所以你应该知道了TCP/IP的关系和作用了。(下面2张图都是网上找的)



    一、HTTP协议的历史(网上找的历史,具体历史我也不知道,HTTP产生的时候我还没出生呢!)

    u   HTTP/0.9: 从1990年就已经用来作为WWW的传输协      议,当时非常简单,只支持GET方法,响应中携带      的消息必须HTML文件。

    u   HTTP/1.0: 1996发布RFC1945,90年后,基于0.9的    各种客户端和服务端的扩展层出不穷,把这些扩

          展进行综合推出新标准HTTP/1.0 。

    u   HTTP/1.1: 1997推出RFC2068,HTTP/1.1的标准。

    u   HTTP/1.1: 1999推出RFC2616,废弃了RFC2068标准。

    二、HTTP协议的基础内容

    http协议的消息类型分为2中类型:一种是请求(Request)消息:由客户端发给服务器的消息。 

                                                      另一种是响应(Response)消息:是服务端回复客户端请求的消息。  

         看下面2张图片看看个返回的都是什么数据:

    这是请求消息:

     

    这个是响应消息:

          我们看看具体每行都是干啥用的?

         我们先看看请求消息的组成:

      这就是一个请求报文,响应报文是对应的 

    对照上面的你就可以清楚看出来了

     

      相对的你可以对应这张图片看下:

    1、请求报文详解:

    接下来就分析下:上面我们刚才得到那份请求消息:

    GET /ex/CookieAutoLogin.aspx HTTP/1.1  :

                   表示向服务器用GET方式请求/ex/CookieAutoLogin.aspx文件,使用HTTP/1.1协议。

    Accept: text/html, application/xhtml+xml, */*

                  表示我当前浏览器可以接收的MIME文件格式。可以根据它判断并返回适当的文件格式。

    Accept-Language: zh-CN 

                  表示当前浏览器支持的语言,中文;很多国际网站默认进入的语言都是通过这个实现的。

    User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)

                  表示客户端浏览器名称、类型、版本等。

    Accept-Encoding: gzip, deflate

                    表示我当前浏览器支持gzip、deflate两种压缩算法。

    Host: localhost:12478

                    表示对应请求网址URL中的Web名称和端口号。

    Connection Keep-Alive:

                         Keep-Alive是永久连接(其实应该是长连接,这时候服务器发送了响应报文之后不直接关闭套接字,而是保持连接一段时间看看还有没有其他请求,如果有请求,这样不仅节省了创建新套接字的时间,还可以节约网络流量和)而如果是close则是在告知服务器本浏览器不想使用永久连接方式(HTTP/1.0使用非永久连接,HTTP/1.1默认使用永久连接)。

    Cookie: username=1; pwd=123

                   这是浏览器向服务器发送和当前网站关联的Cookie,这样在服务器端也能读取浏览器端的Cookie了。

    请求方法的解释:

    GET获取一个URL指定的资源,即资源实体

    HEAD:获取一个指定资源的信息,

    POST:向服务器提交数据

    PUT:向服务器提交资源

    DELETE请求源服务器删除Request-URI标识的资源

    TRACE网络跟踪

    CONNECTPROXY之间的连接管理

    OPTIONS查询能力

    还有其他的一些信息可以查看博客园的

    http://www.cnblogs.com/ryhan/archive/2011/08/09/2132509.html

     1、响应报文详解:

    再来分析响应报文信息:

    HTTP/1.1 302 Found 

               响应行:使用HTTP1.1协议,返回的状态码。具体常见状态吗见后面。(302是只重定向)

    Server: ASP.NET Development Server/10.0.0.0

               表示服务器的类型,这是使用VS开发自启动的小服务器,10版本。

    Date: Wed, 16 May 2012 05:46:46 GMT

                 这个你一看就知道是啥了,(时间)。

    X-AspNet-Version: 2.0.50727       这个是服务器使用的.NET版本信息。

    Location: /ex/Default.aspx      重定向到哪个页面。

    Cache-Control: private            缓存控制:私有。

    Content-Type: text/html; charset=utf-8        表示返回数据的类型 

    Content-Length: 137                表示返回的字节长度。

              这个要知道这是后续数据消息体的长度,响应报文头不包括在内,响应报文头只是描述,返回的具体数据(比如HTML文本、图片数据等)。

     Connection: Close             连接状态:关闭。

    下面这些就是返回的具体消息了。(上面的长度也指代的是这个的长度。)

    <html><head><title>Object moved</title></head><body>

    <h2>Object moved to <a href="%2fex%2fDefault.aspx">here</a>.</h2>

    </body></html>

    响应行中的响应状态

    1xx:指示信息--表示请求已接收,继续处理。

    2xx:成功--表示请求已被成功接收、理解、接受。

    3xx:重定向--要完成请求必须进行更进一步的操作。

    4xx:客户端错误--请求有语法错误或请求无法实现。

    5xx:服务器端错误--服务器未能实现合法的请求。

    常见状态代码、状态描述的说明如下

    200 OK:客户端请求成功。

    400 Bad Request:客户端请求有语法错误,不能被服务器所理解。

    401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用。

    403 Forbidden:服务器收到请求,但是拒绝提供服务。

    404 Not Found:请求资源不存在,举个例子:输入了错误的URL。

    500 Internal Server Error:服务器发生不可预期的错误。

    503 Server Unavailable:服务器当前不能处理客户端的请求,一段时间后可能恢复正常,举个例子:HTTP/1.1 200 OK(CRLF)。

    本文从百度空间搬家到博客园。

  • 相关阅读:
    一文看懂:史上最通俗的视频编码技术详解
    浅谈常见的七种加密算法及实现
    自毁程序
    windows下, 宽字符和窄字符的打印输出
    修改Django自带auth模块的表名
    苹果IOS微信网页cookie缓存清理
    django_rest_framework ModelViewSet不支持PUT方法,PUT修改后不生效
    nginx的access日志打印十六进制x16x03x01x02x00x01
    解决/usr/bin/ld: cannot find -lmariadb报错
    使用antd的Upload组件和axios上传文件
  • 原文地址:https://www.cnblogs.com/yunanwu/p/4168561.html
Copyright © 2011-2022 走看看