文章整理自图书图解Http
- 第一章:使用Http协议访问Web
- 第二章:Http的诞生
- 第三章:网络基础TCP/IP协议
- 一:应用层
- 二:传输层
- 三:网络层
- 四:链路层
- 五:TCP/IP通信传输流
- 第四章:IP、TCP、DNS
- 一:负责传输的IP协议
- 二:负责可靠性的TCP协议
- 三:负责域名解析的DNS服务
- 第六章:各种协议Http协议的关系
- 第七章:URI和URL
- 一:协议名称
- 二:登录信息
- 三:服务器地址
- 四:服务器端口号
- 五:查询字符串
- 六:片段标识符
第一章:使用Http协议访问Web
发送请求获取服务器资源的web服务浏览器等,都可以称客户端。
web使用Http超文本传输协议作为规范,可以说Web服务就是建立在Http协议上通信的。
Http通常被翻译为超文本传输协议,严格来讲应该叫做超文本转移协议。
第二章:Http的诞生
Http1.0正式作为标准,Http1.1是当前最主流的版本,Http2.0还是制定中。
第三章:网络基础TCP/IP协议
网络是在TCP/IP协议族的基础上运作的,Http协议是该协议族的一个子集。
互联网相关联的协议集合起来总称为TCP/IP协议族,他是在IP协议通信过程中的使用到的协议族的统称。
TCP/IP协议族最重要一点就是分层。TCP/IP协议族按层次分别分为一下四层:应用层、传输层、网络层、数据链路层。
一:应用层
TPC/IP协议族当中包含很多应用该服务协议,包含FTP和HTTP,DNS也是应用层协议。
二:传输层
传输层对上层应用层,提供处于网络连接中的两台计算机之前数据传输
在传输层有两个性质不同的协议:TCP协议和UDP协议
三:网络层
网络层用来处理网络上流动的数据包。数据包是网络层传输的最小单位,该层规定了通过怎样的路径将数据到对方计算机,并将数据包正确完整的传输给对方。
与对方计算机之前通过多台计算机或者网络设备进行传输时,网层所起的作用就是在众多的选项中选择一条传输线路。
四:链路层
网络接口层。
用来处理连接网络的硬件部分,包括控制操作系统,硬件的设备驱动,网络适配器也叫作网卡光纤等物理可见部分,还包括连接器等一切传输媒。硬件上的范畴均在链路层的作用范畴之内。
五:TCP/IP通信传输流
利用TCP/IP协议族进行网络通讯的时候,会通过分层顺序与对方进行通信。发送端从应用层往下走,接收端从链路层往上走。
我们使用Http举例来讲,应用层基于Http协议封装好对应的数据叨叨传输层的时候,TCP/IP协议为了传输方便把从应用层接收到的数据(Http请求报文)进行分割,并在各个报文上打上标记序号和端口号发送给网络层
网络层基于IP协议,增加作为通信目的的MAC地址后转发给链路层。这样一来发往网络的通信请求的准备就齐全了。
接收端在链路层接收到数据,按照顺序往上边进行发送。当传输到应用层,才算真正的接收到由客户端发送过来的HTTP请求。
发送端在层与层之间进行传输数据时,没经过一层必定会打上一个该层的首部信息,接收端在进行层与层之间进行传递的时候,每经过一层会把对应的首部信息消去。
这种把数据信息包装起来的做法叫做封装。
第四章:IP、TCP、DNS
一:负责传输的IP协议
IP协议位于网络层,基于所有的网络系统都会使用到IP协议,IP协议的作用就是把各种数据包传送给对方。而要保证确实传送到对方案例则需要满足各类条件。其中两个重要的条件是IP地址和MAC地址。
IP地址指明了节点被分配到的地址,MAC地址是指的是网卡所属的固定地址,IP地址可以和MAC地址进行配对,IP地址可以变换,但是MAC地址基本上不会改变。
IP间通信依赖MAC地址,网络中进行中转的时候,会利用下一站中转设备的MAC地址来搜索下一个中转目标。
二:负责可靠性的TCP协议
TCP协议位于传输层提供可靠的字节流服务。
为了方便传输,将大块的数据分割成报文段,为单位的数据包进行管理
为了准确无误的将数据送达目标,TCP协议采用了三次握手四次挥手的的策略。
TCP协议将数据包发送出去后,TCP会向对方确认是否成功送达。握手过程使用了TCP的标志:SYN和ACK
发送端首先发送一个带SYN标志的数据包给对方,接收端收到后,同样回传一个带有SYN/ACK标志的数据包以示传到确认信息。同时发送端在回传一个带有ACK标志的数据包,代表握手结束。
若在握手过程中某个阶段中断,TCP协议会再次以相同的顺序发送相同的数据包。换句话说就是从来一次。
除了上述这个手段,TCP还有其他的方式保证通信的可靠性。
三:负责域名解析的DNS服务
DNS和Http一样是应用层协议,提供域名和IP地址之间的相互解析服务。
DNS服务器提供域名查找IP服务,也提供IP地址反查域名服务。
第六章:各种协议Http协议的关系
第七章:URI和URL
URI是统一资源标识符:唯一标识某一个互联网资源
URL是统一字段定位符:定位互联网资源,这个概念表示的是URI的子集。
一:协议名称
使用http或https等协议方案名获取访问资源时要指定协议类型不区分字母大小写,最后附一个冒号也可使用data或javascript这类指定数据或脚本程序的方案名
二:登录信息
指定用户名和密码作为从服务器端获取资源时必要的登录信息(身份认证)。此项是可选项
三:服务器地址
使用绝对 URI必须指定待访问的服务器地址。地址可以是类似hackrip这种DNS可解析的名称,或是192168.11这类IPv4地址名,还可以是[0:0:0:0:0:0:0:1]这样用方括号括起来的IPv6地址名。
四:服务器端口号
指定服务器连接的网络端口号。此项也是可选项,若用户省略则自动使用默认端口号
带层次的文件路径指定服务器上的文件路径来定位特指的资源。这与UNIX系统的文件目录结构相似。
五:查询字符串
针对已指定的文件路径内的资源,可以使用查询字符串传入任意参数。此项可选。
六:片段标识符
使用片段标识符通常可标记出已获取资源中的子资源(文档内的某个位置 )。但在 RFC 中并没有明确规定其使用方法。该项也为可选项。