图解系列--简单的Http协议

1.URI和URL
1.1.URL
URL是统一资源定位符。URL正是使用 Web 浏览器等访问 Web 页面时需要输入的网页地址。比如,http://hackr.jp/就是 URL。
1.2.URI
统一资源标识符。
URI 用字符串标识某一互联网资源,而URL表示资源的地点(互联网上所处的位置)。可见URL是URI的子集。
在这里插入图片描述
上述均是URI。

_1.URI格式
(1).绝对URI
在这里插入图片描述

协议方案名:
上述http:指定协议方案名,也可用data:javascript:这类指定数据或脚本程序的方案名。
登录信息:
指定用户名和密码作为从服务器端获取资源时必要的登录信息(身份认证)。此项是可选项。
服务器地址:
使用绝对 URI 必须指定待访问的服务器地址。地址可以是类似hackr.jp这种DNS可解析的名称,或是192.168.1.1这类 IPv4 地址名,还可以是 [0:0:0:0:0:0:0:1] 这样用方括号括起来的IPv6地址名。
服务器端口号:
指定服务器连接的网络端口号。此项也是可选项,若用户省略,则自动使用默认端口号。
带层次的文件路径:
指定服务器上的文件路径来定位特指的资源。这与UNIX系统的文件目录结构相似。
查询字符串:
针对已指定的文件路径内的资源,可以使用查询字符串传入任意参数。此项可选。
片段标识符:
使用片段标识符通常可标记出已获取资源中的子资源(文档内的某个位置)。但在RFC中并没有明确规定其使用方法。该项也为可选项。

2.HTTP
2.1.请求和响应格式
2.1.1.请求
在这里插入图片描述
GET请求实例。请求报文是由请求方法、请求 URI、协议版本、可选的请求首部字段和内容实体构成的。
在这里插入图片描述
POST请求实例

2.1.2.响应
在这里插入图片描述

服务端响应实例。响应报文基本上由协议版本、状态码(表示请求成功或失败的数字代码)、用以解释状态码的原因短语、可选的响应首部字段以及实体主体构成。

2.2.HTTP是不保存状态的协议
协议对于发送过的请求或响应都不做持久化处理。HTTP协议自身不保存之前发送过的请求或响应。
使用HTTP协议,每当有新的请求发送时,就会有对应的新响应产生。协议本身并不保留之前一切的请求或响应报文的信息。
HTTP/1.1虽然是无状态协议,但为了实现期望的保持状态功能,于是引入了Cookie技术。有了Cookie再用HTTP协议通信,就可以管理状态了。

2.3.请求 URI 定位资源
在这里插入图片描述
指定URI的方式。

如果不是访问特定资源而是对服务器本身发起请求,可以用一个 * 来代替请求 URI。下面这个例子是查询 HTTP 服务器端支持的 HTTP 方法种类。
在这里插入图片描述
2.4.告知服务器意图的HTTP方法
2.4.1.GET
GET方法用来请求访问已被URI识别的资源。
如果请求的资源是文本,那就保持原样返回;如果是像CGI那样的程序,则返回经过执行后的输出结果。
在这里插入图片描述
2.4.2.POST
POST方法用来传输实体的主体。
用GET方法也可以传输实体的主体,但一般不用GET方法进行传输,而是用POST方法。
在这里插入图片描述

2.4.3.PUT
PUT 方法用来传输文件。实现文件上传到服务端。
要求在请求报文的主体中包含文件内容,然后保存到请求URI指定的位置。
鉴于HTTP/1.1的PUT方法自身不带验证机制,任何人都可以上传文件,存在安全性问题,因此一般的Web网站不使用该方法。
在这里插入图片描述
2.4.4.HEAD
HEAD方法和GET方法一样,只是不返回报文主体部分。用于确认URI的有效性及资源更新的日期时间等。
在这里插入图片描述
2.4.5.DELETE
DELETE方法用来删除文件。DELETE方法按请求URI删除指定的资源。
HTTP/1.1 的 DELETE 方法本身和 PUT 方法一样不带验证机制,所以一般的 Web 网站也不使用 DELETE 方法。
在这里插入图片描述
2.4.6.OPTIONS
OPTIONS 方法用来查询针对请求 URI 指定的资源支持的方法。
在这里插入图片描述
2.4.7.TRACE
TRACE 方法是让 Web 服务器端将之前的请求通信环回给客户端的方法。
发送请求时,在 Max-Forwards 首部字段中填入数值,每经过一个服务器端就将该数字减 1,当数值刚好减到 0 时,就停止继续传输,最
后接收到请求的服务器端则返回状态码 200 OK 的响应。

客户端通过 TRACE 方法可以查询发送出去的请求是怎样被加工修改/ 篡改的。这是因为,请求想要连接到源目标服务器可能会通过代理中转,TRACE 方法就是用来确认连接过程中发生的一系列操作。

但TRACE 方法本来就不怎么常用,再加上它容易引发XST(Cross-Site Tracing,跨站追踪)攻击,通常就更不会用到了。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2.4.8.CONNECT
CONNECT方法要求在与代理服务器通信时建立隧道,实现用隧道协议进行TCP通信。
主要使用 SSL(Secure Sockets Layer,安全套接层)和 TLS(Transport Layer Security,传输层安全)协议把通信内容加密后经网络隧道传输。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.5.使用方法下达命令
向请求 URI 指定的资源发送请求报文时,采用称为方法的命令。
方法的作用在于,可以指定请求的资源按期望产生某种行为。方法中有 GET、POST 和 HEAD 等。
方法名区分大小写,注意要用大写字母。
在这里插入图片描述
2.6.持久连接节省通信量
HTTP 协议的初始版本中,每进行一次 HTTP 通信就要断开一次 TCP连接。
在这里插入图片描述
(1).持久连接
持久连接的特点是,只要任意一端没有明确提出断开连接,则保持 TCP 连接状态。
在 HTTP/1.1 中,所有的连接默认都是持久连接,但在 HTTP/1.0 内并未标准化。

(2).管线化
持久连接使得多数请求以管线化(pipelining)方式发送成为可能。管线化技术出现后,不用等待响应亦可直接发送下一个请求。这样就能够做到同时并行发送多个请求。

2.7.使用 Cookie 的状态管理
HTTP 是无状态协议,它不对之前发生过的请求和响应的状态进行管理。
假设要求登录认证的 Web 页面本身无法进行状态的管理(不记录已登录的状态),那么每次跳转新页面不是要再次登录,就是要在每次
请求报文中附加参数来管理登录状态。

保留无状态协议这个特征的同时又要解决类似的矛盾问题,于是引入了 Cookie 技术。Cookie 技术通过在请求和响应报文中写入 Cookie 信
息来控制客户端的状态。

Cookie 会根据从服务器端发送的响应报文内的一个叫做 Set-Cookie 的首部字段信息,通知客户端保存 Cookie。当下次客户端再往该服务器
发送请求时,客户端会自动在请求报文中加入 Cookie 值后发送出去。

服务器端发现客户端发送过来的 Cookie 后,会去检查究竟是从哪一个客户端发来的连接请求,然后对比服务器上的记录,最后得到之前的状态信息。
在这里插入图片描述
在这里插入图片描述
(1).请求报文(没有 Cookie 信息的状态)
在这里插入图片描述
(2).响应报文(服务器端生成 Cookie 信息)
在这里插入图片描述
(3).请求报文(自动发送保存着的 Cookie 信息)
在这里插入图片描述

  • 23
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

raindayinrain

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值