计算机网络 第六章(应用层)

参考教程:6.1 应用层概述_哔哩哔哩_bilibili

一、应用层概述

1、应用层的地位

应用层是计算机网络体系结构的最顶层,是设计和建立计算机网络的最终目的,也是计算机网络中发展最快的部分。

b2d12efd09bc4484b1e2ead9ecdd9752.png

2、一些经典的网络应用

83bd60504d8e4fee8f68b8ea009535a0.png

二、客户/服务器方式和对等方式

1、网络应用程序在各种端系统上的组织方式和它们之间的关系

网络应用程序运行在处于网络边缘的不同的端系统上,通过彼此间的通信来共同完成某项任务。因此,开发一种新的网络应用首先要考虑的问题就是网络应用程序在各种端系统上的组织方式和它们之间的关系,目前流行的主要有以下两种:

①一种是客户/服务器方式,也称为C/S(Client/Server)方式

②一种是对等方式,也称为P2P(Peer-to-Peer)方式

2、客户/服务器方式

(1)客户和服务器是指通信中所涉及的两个应用进程。客户/服务器方式所描述的是进程之间服务和被服务的关系。

(2)如下图所示,处于网络边缘的主机A中运行的是客户程序,正在运行的客户程序称为客户进程,也可简称为客户,运行客户进程的主机应称为客户计算机,但有时也简称为客户;处于网络边缘的主机B中运行的是服务器程序,正在运行的服务器程序称为服务器进程,也可简称为服务器,运行服务器进程的主机应称为服务器计算机,但有时也简称为服务器。

(3)在客户/服务器方式下,客户向服务器请求服务,服务器收到服务请求后向客户提供服务,也就是说,客户是服务的请求方,服务器是服务的提供方。

(4)服务器总是处于运行状态,并等待客户的服务请求。服务器具有固定端口号(例如HTTP服务器的默认端口号为80),而运行服务器的主机也具有固定的IP地址。

cae95390a262492d959b2a5a843f6c7f.png

(5)C/S方式是因特网上传统的、同时也是最成熟的方式,很多我们熟悉的网络应用采用的都是C/S方式,包括万维网WWW、电子邮件、文件传输FTP等。

(6)基于C/S方式的应用服务通常是服务集中型的,即应用服务集中在网络中比客户计算机少得多的服务器计算机上。由于一台服务器计算机要为多个客户机提供服务,在C/S应用中,常会出现服务器计算机跟不上众多客户机请求的情况,为此,在C/S应用中,常用计算机群集(或服务器场)构建一个强大的虚拟服务器。

3、对等方式

(1)在P2P方式中,没有固定的服务请求者和服务提供者,分布在网络边缘各端系统中的应用进程是对等的,被称为对等方。对等方相互之间直接通信,每个对等方既是服务的请求者,又是服务的提供者。

(2)如下图所示,处于网络边缘的主机C、D、E、F中运行着同一种P2P程序,例如某种网络下载工具软件。E和F中的P2P进程互为对等方,C和D中的P2P进程互为对等方,而E中的P2P进程还和D中的P2P进程互为对等方。可以想象成E的P2P进程正在从F下载文件,与此同时还为D的P2P进程提供下载服务。

c06f5727a90949fc98c068b808b26623.png

(3)目前,在因特网上流行的P2P应用主要包括P2P文件共享、即时通信、P2P流媒体、分布式存储等。

(4)基于P2P的应用是服务分散型的,因为服务不是集中在少数几个服务器计算机中,而是分散在大量对等计算机中,这些计算机并不为服务提供商所有,而是为个人控制的桌面计算机和笔记本电脑,它们通常位于住宅、校园和办公室中。

(5)P2P方式的最突出特性之一就是它的可扩展性,因为系统每增加一个对等方,不仅增加的是服务的请求者,同时也增加了服务的提供者,系统性能不会因规模的增大而降低。

(6)P2P方式具有成本上的优势,因为它通常不需要庞大的服务器设施和服务器带宽。为了降低成本,服务提供商对于将P2P方式用于应用的兴趣越来越大。

三、动态主机配置协议DHCP

1、DHCP的作用

(1)如下图所示,有这样一个网络拓扑。需要给网络中的各主机正确配置IP地址、子网掩码、默认网关、DNS服务器等网络相关配置信息,才能使用户主机正常访问Web服务器。

(2)在网络中的主机数量比较多的情况下,如果采取手工配置,那么工作量将会比较大,并且容易出错。

(3)如果在网络中添加一台DHCP服务器在该服务器中设置好可为网络中其它各主机配置的网络配置信息,网络中各主机开机后自动启动DHCP程序,向DHCP服务器请求自己的网络配置信息,这样,网络中的各主机就都可以从DHCP服务器自动获取网络配置信息,而不用手工配置。

cf936eb7d12a492aaa98a34e67fb18cc.png

2、DHCP的工作过程

(1)如下图所示,假设网络中有两台DHCP服务器和多台用户主机。DHCP使用客户/服务器方式在DHCP服务器上运行DHCP服务器进程(也可简称为DHCP服务器),在用户主机上运行DHCP客户进程(也可简称为DHCP客户)。

(2)DHCP是TCP/IP协议体系应用层中的协议,它使用运输层的UDP所提供的服务,也就是说,DHCP报文在运输层会被封装成为UDP用户数据报,DHCP服务器使用的UDP端口是67DHCP客户使用的UDP端口是68,这两个UDP端口都是熟知端口。

09e55ae168ca405f9c8d0e4cf484b30d.png

(3)封装有DHCP报文的UDP用户数据报在网络层会被封装成IP数据报,然后再根据所使用的网络接口,封装成相应的数据链路层的帧进行发送,例如封装成以太网帧。(为简单起见,如无特殊需要,后面的描述不再每次都描述DHCP报文逐层封装的过程)

(4)DHCP客户与DHCP服务器的交互过程:

①当启用主机的DHCP后,DHCP客户将广播发送DHCP发现报文

[1]封装该报文的IP数据报的源IP地址为0.0.0.0,这是因为主机目前还未分配到IP地址,因此使用该地址来代替;目的IP地址为广播地址255.255.255.255,之所以进行广播发送,是因为主机现在并不知道网络中有哪几个DHCP服务器、它们的IP地址各是什么。

[2]由于是广播的IP数据报,因此网络中的所有设备都会收到该IP数据报,并对其层层解封,解封出封装有DHCP发现报文的UDP用户数据报。

[3]DHCP报文的格式比较复杂,对于DHCP发现报文,只需知道其内部封装有事物IDDHCP客户端的MAC地址即可。

②对于DHCP客户,其应用层没有监听该UDP用户数据报目的端口67的进程也就是DHCP服务器进程,因此无法交付DHCP发现报文,只能丢弃;而对于DHCP服务器,其应用层始终运行着DHCP服务器进程,因此会接受该DHCP发现报文并作出响应。

6983640236774d09bc4b27e9d01ded20.png

DHCP服务器收到DHCP发现报文后,根据其中封装的DHCP客户端的MAC地址来查找自己的数据库,看是否有针对该MAC地址的配置信息

[1]如果有针对该MAC地址的配置信息,则使用这些配置信息来构建并发送DHCP提供报文;如果没有针对该MAC地址的配置信息,则采用默认配置信息来构建并发送DHCP提供报文

[2]封装该报文的IP数据报的源IP地址为DHCP服务器的IP地址目的IP地址仍为广播地址,仍然使用广播地址的原因是主机目前还没有配置IP地址,为了使主机可以收到,只能发送广播,这样一来,网络中的所有设备都会收到该IP数据报,并对其层层解封,解封出封装有DHCP 提供报文的UDP用户数据报。

[3]DHCP服务器从自己的IP地址池中挑选待租用给主机的IP地址时,会使用ARP来确保所选IP地址未被网络中其它主机占用。

[4]DHCP提供报文中还封装有配置信息,例如IP地址、子网掩码、地址租期、默认网关、DNS服务器等。

④对于DHCP服务器,其应用层没有监听该UDP用户数据报目的端口68的进程也就是DHCP客户进程,因此无法交付DHCP提供报文,只能丢弃;而对于DHCP客户,其应用层运行着DHCP客户进程,因此会接受该DHCP提供报文并作出相应处理。

06182a76269c432e92df58eac919b6c4.png

DHCP客户收到DHCP提供报文后,根据其中封装的事物ID判断该报文是否是自己所请求的报文,换句话说,如果该事物ID与自己之前发送的DHCP发现报文中封装的事物ID相等,就表明这是自己所请求的报文,就可以接受该报文,否则就丢弃该报文。

⑥在本例中,DHCP客户会收到两个DHCP服务器发来的DHCP提供报文,DHCP客户从中选择一个,一般来说,选择先到的那个,并向所选择的DHCP服务器发送DHCP请求报文

[1]封装该报文的IP数据报的源IP地址仍为0.0.0.0,因为此时DHCP客户才从多个DHCP服务器中挑选一个作为自己的DHCP服务器,它首先需要征得该服务器的同意,之后才能正式使用向该DHCP服务器租用的IP地址;目的IP地址仍为广播地址,这样做的目的是不用向网络中的每一个DHCP服务器单播发送DHCP请求报文来告知它们是否请求它们作为自己的DHCP服务器。

[2]DHCP请求报文中封装有事物ID、DHCP客户端的MAC地址、接受的租约中的IP地址、提供此租约的DHCP服务器端的IP地址等信息。

⑦在本例中,假设DHCP客户选择DHCP服务器1作为自己的DHCP服务器,并且DHCP服务器1接受该请求,于是DHCP服务器1给DHCP客户发送DHCP确认报文。封装该报文的IP数据报的源IP地址为DHCP服务器1的IP地址目的IP地址仍为广播地址

db570cb4dc564bee8bc26ba44abcf5b3.png

DHCP客户收到该确认报文后,就可以使用所租用到的IP地址了。在使用租用到的IP地址之前,主机还会使用ARP检测该IP地址是否已被网络中其它主机占用,若被占用,给DHCP服务器发送DHCP谢绝报文撤销IP地址租约,并重新发送DHCP发现报文;若未被占用,就可以使用租约中的IP地址与网络中其它主机通信了。

20e1f3fc16654cb19a7ef1bda9f4a930.png

当租用期过了一半时DHCP客户会向DHCP服务器发送DHCP请求报文来请求更新租用期。封装该报文的IP数据报的源IP地址为DHCP客户之前租用到的IP地址目的IP地址为DHCP服务器1的地址

[1]DHCP服务器若同意,则发回DHCP确认报文,这样,DHCP客户就得到了新的租用期。

[2]DHCP服务器若不同意,则发回DHCP否认报文,这时,DHCP客户必须立即停止使用之前租用的IP地址,并重新发送DHCP发现报文来重新申请IP地址。

[3]DHCP服务器若未做出响应,则在租用期过了87.5%时,DHCP客户必须重新发送DHCP请求报文,然后继续等待DHCP服务器可能做出的反应,若DHCP服务器仍未做出响应,则当租用期到期后,DHCP客户必须立即停止使用之前租用的IP地址,并重新发送DHCP发现报文来重新申请IP地址。

⑩DHCP客户可以随时提前终止DHCP服务器所提供的租用期,这时只需向DHCP服务器发送DHCP释放报文段即可。

d77d3e294ac1465296ff3b0fc8f94f87.png

3、DHCP中继代理

(1)如下图所示,有这样一个网络拓扑。路由器左侧网络中的主机不能自动获取到IP地址等网络配置信息,因为该网络中的主机广播发送DHCP发现报文,但该广播报文不会被路由器转发,而是丢弃。

(2)解决方法是给路由器配置DHCP服务器的IP地址并使之成为DHCP中继代理,这样,该网络中的各主机就可以通过DHCP来自动获取到网络配置信息了。当该路由器收到广播的DHCP发现报文后,会将其单播转发给DHCP服务器,DHCP客户和DHCP服务器通过该路由器的后续交互过程不再赘述。

9d04a89c33b543fd91ba1a92dd412375.png

(3)使用DHCP中继代理的主要原因是不是每一个网络上都设置一个DHCP服务器,因为这样会使DHCP服务器的数量太多。

四、域名系统DNS

1、域名系统DNS的作用

(1)如下图所示,因特网中的某台主机要访问某台Web服务器,只需在用户主机中运行某个浏览器软件,在其地址栏中输入要访问的Web服务器的域名并按下回车键,即可访问到Web服务器所提供的内容。即使不使用域名,也可以通过IP地址来寻址目的主机,只是域名与IP地址相比,便于人们记忆,因此,对于大多数网络应用,一般使用域名来访问目的主机,而不是直接使用IP地址来访问。

(2)当我们在浏览器地址栏中输入某个Web服务器的域名时:

①用户主机会首先在自己的DNS高速缓存中查找该域名所对应的IP地址,如果没有找到,则会向网络中的某台DNS服务器查询。

②DNS服务器中有域名和IP地址映射关系的数据库,当DNS服务器收到DNS查询报文后,在其数据库中进行查寻,之后将查寻结果发送给用户主机。(DNS报文使用运输层的UDP协议进行封装,运输层端口号为53)

③接着用户主机中的浏览器可以通过Web服务器的IP地址对其进行访问了。

154da97107dd452dbd7803891168a2d4.png

(3)因特网不能只使用一台DNS服务器,因为因特网的规模很大,只使用一台域名服务器肯定会因为超负荷而无法正常工作,而且一旦域名服务器出现故障,整个因特网就会瘫痪。

①早在1983年,因特网就开始采用层次结构的命名树作为主机的名字(即域名),并使用分布式的域名系统DNS。

②DNS使大多数域名都在本地解析,仅少量解析需要在因特网上通信,因此系统效率很高。

③由于DNS是分布式系统,即使单个计算机出了故障,也不会妨碍整个系统的正常运行。

2、因特网域名系统所采用的层次树状结构的域名结构

(1)域名的结构由若干个分量组成,各分量之间用“点”隔开,分别代表不同级别的域名。

①每一级的域名都由英文字母和数字组成,不超过63个字符,不区分大小写字母。

②级别最低的域名写在最左边,而级别最高的顶级域名写在最右边。

③完整的域名不超过255个字符。

85678b9dfa8b4ce39c3c94c7ae75de93.png

(2)域名系统既不规定一个域名需要包含多少个下级域名,也不规定每一级的域名代表什么意思。

(3)各级域名由其上一级的域名管理机构管理,而最高的顶级域名则由因特网名称与数字地址分配机构ICANN进行管理。

5db9c9de01b246aa9ed7a8499bf2f93b.png

(4)顶级域名TLD(Top Level Domain)分为三类:

国家顶级域名nTLD:采用ISO 3166的规定,如cn表示中国、us表示美国、uk表示英国等等。

通用顶级域名gTLD:最常见的通用顶级域名有七个,即com(公司企业)、net(网络服务机构)、org(非营利性组织)、int(国际组织)、edu(美国教育结构)、gov(美国政府部门)、il(美国军事部门)。

反向域arpa:用于反向域名解析,即IP地址反向解析为域名。

(5)在国家顶级域名下注册的二级域名均由该国家自行确定,例如,顶级域名为jp的日本,将其教育和企业机构的二级域名定为ac和co,而不用edu和com。

①我国则将二级域名划分为以下两类:

[1]类别域名:共七个,即ac(科研机构)、com(工、商、金融等企业)、edu(教育机构)gov(政府部门)、net(提供网络服务的机构)、mil(军事机构)和org(非营利性组织)。

[2]行政区域名:共34个,适用于我国的各省、自治区、直辖市,例如bi为北京市、sh为上海市js为江苏省,等等。

②需要注意的是,名称相同的域名其等级未必相同。

(6)因特网的域名空间:

bfd6c324fc1f4d0ba55f61d6d50219e3.png

①这种按等级管理的命名方法便于维护名字的唯一性,并且也容易设计出一种高效的域名查询机制。

②需要注意的是,域名只是个逻辑概念,并不代表计算机所在的物理地点。

3、域名服务器

(1)域名和IP地址的映射关系必须保存在域名服务器中,供所有其它应用查询,但显然不能将所有信息都储存在一台域名服务器中。

(2)DNS使用分布在各地的域名服务器来实现域名到IP地址的转换。

(3)域名服务器可以划分为以下四种不同的类型:

根域名服务器

[1]根域名服务器是最高层次的域名服务器,每个根域名服务器都知道所有的顶级域名服务器的域名及其1P地址。

[2]因特网上共有13个不同IP地址的根域名服务器,尽管我们将这13个根域名服务器中的每一个都视为单个的服务器,但“每台服务器”实际上是由许多分布在世界各地的计算机构成的服务器群集。

[3]当本地域名服务器向根域名服务器发出查询请求时,路由器就把查询请求报文转发到离这个DNS客户最近的一个根域名服务器,这就加快了DNS的查询过程,同时也更合理地利用了因特网的资源。

[4]根域名服务器通常并不直接对域名进行解析,而是返回该域名所属顶级域名的顶级域名服务器的IP地址。

顶级域名服务器

[1]这些域名服务器负责管理在该顶级域名服务器注册的所有二级域名。

[2]当收到DNS查询请求时,这些域名服务器就给出相应的回答(可能是最后的结果,也可能是下一级权限域名服务器的IP地址)。

权限域名服务器

[1]这些域名服务器负责管理某个区的域名。

[2]每一个主机的域名都必须在某个权限域名服务器处注册登记,因此权限域名服务器知道其管辖的域名与IP地址的映射关系。

[3]另外,权限域名服务器还知道其下级域名服务器的地址。

本地域名服务器

[1]本地域名服务器不属于上述的域名服务器的等级结构。

[2]当一个主机发出DNS请求报文时,这个报文就首先被送往该主机的本地域名服务器,本地域名服务器起着代理的作用,会将该报文转发到上述的域名服务器的等级结构中。

[3]每一个因特网服务提供者ISP,一个大学,甚至一个大学里的学院,都可以拥有一个本地域名服务器,它有时也称为默认域名服务器。

[4]本地域名服务器离用户较近,一般不超过几个路由器的距离,也有可能就在同一个局域网中。

[5]本地域名服务器的IP地址需要直接配置在需要域名解析的主机中。

4、域名解析的过程

(1)域名解析包含两种查询方式:递归查询迭代查询

(2)递归查询:

①假设下图中的主机想知道域名y.abc.com的IP地址,主机首先向其本地域名服务器进行递归查询。

②本地域名服务器收到递归查询的委托后,也采用递归查询的方式向某个根域名服务器查询。

③根域名服务器收到递归查询的委托后,也采用递归查询的方式向某个顶级域名服务器查询。

④顶级域名服务器收到递归查询的委托后,也采用递归查询的方式向某个权限域名服务器查询。

⑤当查询到域名所对应的IP地址后,查询结果会在之前受委托的各域名服务器之间传递,最终传回给用户主机。

28cd6df4d8de48a9be3f31906eb29c6b.png

(3)迭代查询:

①假设下图中的主机想知道域名y.abc.com的IP地址,主机首先向其本地域名服务器进行递归查询。

②本地域名服务器采用迭代查询,它先向某个根域名服务器查询。

③根域名服务器告诉本地域名服务器下一次应查询的顶级域名服务器的IP地址。

④本地域名服务器向顶级域名服务器进行迭代查询。

⑤顶级域名服务器告诉本地域名服务器下一次应查询的权限域名服务器的IP地址。

⑥本地域名服务器向权限域名服务器进行迭代查询。

⑦权限域名服务器告诉本地域名服务器所查询的域名的IP地址。

⑧本地域名服务器最后把查询结果告诉主机。

ea0ce8cd782c4f40a5d5ced336b30f67.png

(4)由于递归查询对于被查询的域名服务器负担太大,通常采用以下模式:从请求主机到本地域名服务器的查询是递归查询,而其余的查询是迭代查询。

5、高速缓存

(1)为了提高DNS的查询效率,并减轻根域名服务器的负荷和减少因特网上的DNS查询报文数量,在域名服务器中广泛地使用了高速缓存。高速缓存用来存放最近查询过的域名以及从何处获得域名映射信息的记录。

(2)如下图所示,如果不久前已经有用户查询过域名为y.abc.com的IP地址,刘本地域名服务器的高速缓存中应该存有该域名对应的IP地址。当主机向本地域名服务器递归查询该域名时,本地域名服务器就没有必要再向某个根域名服务器进行迭代查询了,而是直接把高速缓存中存放的上次查询结果(即该域名的IP地址)告诉用户主机。

1b6fed2f0a8e4e75b8ad35467986790a.png

(3)由于域名到IP地址的映射关系并不是永久不变,为保持高速缓存中的内容正确,域名服务器应为每项内容设置计时器并删除超过合理时间的项(例如,每个项目只存放两天)。

(4)不但在本地域名服务器中需要高速缓存,在用户主机中也很需要。

①许多用户主机在启动时从本地域名服务器下载域名和IP地址的全部数据库,维护存放自己最近使用的域名的高速缓存,并且只在从缓存中找不到域名时才向域名服务器查询。

②同理,主机也需要保持高速缓存中内容的正确性。

五、文件传送协议FTP

1、文件传送协议概述

(1)将某台计算机中的文件通过网络传送到可能相距很远的另一台计算机中,是一项基本的网络应用,即文件传送。

(2)文件传送协议FTP(File Transfer Protocol) 是因特网上使用得最广泛的文件传送协议。

①FTP提供交互式的访问,允许客户指明文件的类型与格式(如指明是否使用ASCII码),并允许文件具有存取权限(如访问文件的用户必须经过授权,并输入有效的口令)。

②FTP屏蔽了各计算机系统的细节,因而适合于在异构网络中任意计算机之间传送文件。

(3)在因特网发展的早期阶段,用FTP传送文件约占整个因特网的通信量的三分之一,而由电子邮件和域名系统所产生的通信量还要小于FTP所产生的通信量。只是到了1995年,万维网WWW的通信量才首次超过了FTP。

2、文件传送协议的应用

(1)如下图所示,假设网络中有一台FTP服务器和多台用户主机。FTP使用客户/服务器方式在FTP服务器上运行FTP服务器进程(也可简称为FTP服务器),在用户主机上运行FTP客户进程(也可简称为FTP客户)。

(2)因特网上的FTP客户计算机可将各种类型的文件上传到FTP服务器计算机,FTP客户计算机也可以从FTP服务器计算机下载文件。

2d1fff1ea2114632a807d05b40e847b2.png

(3)根据应用需求的不同,FTP服务器可能需要一台高性能和高可靠性的服务器计算机,也可能只需要一台普通的个人计算机即可。本例采用普通的个人计算机作为FTP服务器计算机。

(4)为了简单起见,假设FTP客户计算机与FTP服务器计算机处于同一个局域网中,在FTP服务器计算机中创建FTP服务器。创建FTP服务器可以使用第三方的FTP服务器软件,也可以使用操作系统自带的FTP服务器软件,例如在windows系统中使用其自带的FTP服务器功能添加一个FTP站点(FTP服务器),其IP地址为192.168.124.16,FTP客户计算机可以使用浏览器软件通过该IP地址来访间FTP服务器。

ec39cb1f428f4ba9981ec638c2e4bfad.png

(5)FTP的常见用途:

①在计算机之间传输文件,尤其是用于批量传输文件。

②让网站设计者将构成网站内容的大量文件批量上传到他们的Web服务器。

3、FTP的基本工作原理

(1)主动模式:

①如下图所示,FTP服务器监听熟知端口号21,FTP客户随机选择一个临时端口号与其建立TCP连接,这条TCP连接用于FTP客户与服务器之间传送FTP的相关控制命令,也就是说,这条TCP连接是FTP客户与服务器之间的命令通道

②当有数据要传输时,FTP客户通过命令通道告知FTP服务器来与自己的另一个临时端口号建立TCP连接(即建立数据通道)。FTP客户随机选择另一个临时端口号,FTP服务器使用自己的熟知端口号20与其建立TCP连接,这条TCP连接用于FTP客户与服务器之间传送文件,也就是说,这条TCP连接是FTP客户与服务器之间的数据通道

③由于在建立数据通道时,FTP服务器主动连接FTP客户,因此称为主动模式

④控制连接在整个会话期间一直保持打开,用于传送FTP相关控制命令;数据连接用于文件传输,在每次文件传输时才建立,传输结束就关闭。

37918ba3cf7047b09a6c96c0fa50f804.png

(2)被动模式:

①如下图所示,对于FTP客户与服务器之间命令通道的建立,被动模式与主动模式没什么不同。

②当有数据要传输时,FTP客户通过命令通道告知FTP服务器开启某个协商好的临时端口被动等待来自FTP客户的TCP连接(即建立数据通道)。FTP客户随机选择另一个临时端口号,FTP服务器随机选择一个临时端口号,FTP客户发起与FTP服务器的TCP连接以建立数数据通道。

③由于在建立数据通道时,FTP服务器被动等待FTP客户的连接,因此称为被动模式

④控制连接在整个会话期间一直保持打开,用于传送FTP相关控制命令;数据连接用于文件传输,在每次文件传输时才建立,传输结束就关闭。

05aa9287dd21488eabb51d14db81583a.png

六、电子邮件

1、电子邮件概述

(1)电子邮件(E-mail)是因特网上最早流行的一种应用,并且仍然是当今因特网上最重要、最实用的应用之一。

(2)传统的电话通信属于实时通信,存在以下两个缺点:

①电话通信的主叫和被叫双方必须同时在场。

②一些不是十分紧迫的电话也常常不必要地打断人们的工作或休息。

(3)电子邮件与邮政系统的寄信相似:

①发件人将邮件发送到自己使用的邮件服务器。

②发件人的邮件服务器将收到的邮件按其目的地址转发到收件人邮件服务器中的收件人邮箱。

③收件人在方便的时候访问收件人邮件服务器中自己的邮箱,获取收到的电子邮件。

(4)电子邮件使用方便、传递迅速而且费用低廉。它不仅可以传送文字信息,而且还可附上声音和图像。

2、电子邮件系统的主要组成构件

(1)电子邮件系统采用客户/服务器方式。

(2)电子邮件系统的三个主要组成构件:用户代理、邮件服务器和电子邮件所需的协议。

用户代理是用户与电子邮件系统的接口,又称为电子邮件客户端软件。在发送方的计算机中需要使用用户代理来发送邮件,在接收方的计算机中同样也需要使用用户代理来接收邮件。

邮件服务器是电子邮件系统的基础设施。因特网上所有的ISP都有邮件服务器,其功能是发送和接收邮件,同时还要负责维护用户的邮箱,可以简单地认为邮件服务器中有很多邮箱,还有用来缓存待转发邮件的缓存。

③发送方使用用户代理通过邮件发送协议(例如SMTP,Simple Mail Transfer Protocol)将邮件发送给发送方邮件服务器,发送方邮件服务器同样通过邮件发送协议将邮件发送给接收方邮件服务器,接收方在方便的时候使用用户代理通过邮件读取协议(例如POP3,Post Office Protocol)从接收方邮件服务器读取邮件。也就是说,电子邮件所需的协议包括邮件发送协议(例如SMTP)和邮件读取协议(例如POP3、IMAP)。

4fc422c4abc742c09e548261400f5993.png

3、邮件发送和接收的具体过程

(1)发送方的用户代理作为SMTP客户与发送方邮件服务器中的SMTP服务器进行TCP连接,然后基于这条连接,使用SMTP协议来发送邮件给发送方邮件服务器。

(2)发送方邮件服务器中的SMTP客户与接收方邮件服务器中的SMTP服务器进行TCP连接,然后基于这条连接,使用SMTP协议来发送已收到的待转发邮件给接收方邮件服务器。

(3)接收方的用户代理作为POP3客户与接收方邮件服务器中的POP3服务器进行TCP连接,然后基于这条连接,使用POP3协议从接收方邮件服务器读取邮件。

5b190c66479045dab6fe211addb156a2.png

4、简单邮件传送协议SMTP的基本工作原理

(1)如下图所示,以发送方邮件服务器使用SMTP协议给接收方邮件服务器发送待转发的邮件为例。

(2)发送方邮件服务器周期性地扫描邮件缓存,如果发现有待转发的邮件,则发送方邮件服务器中的SMTP客户会与接收方邮件服务器中的SMTP服务器进行TCP连接,端口号为25

SMTP客户可以基于这条TCP连接给SMTP服务器发送SMTP命令,共14条;SMTP服务器也会给SMTP客户发送相应的应答,共21种。

SMTP客户与服务器之间通过命令与应答的交互方式,最终实现SMTP客户发送邮件给SMTP服务器

87a8e95b72b34266886eeccaf1040b5a.png

(3)当TCP连接建立成功后,SMTP服务器会主动推送服务就绪应答给SMTP客户,应答代码220后面可能跟有描述信息。SMTP客户收到该应答后,向服务器表明身份,告知自己SMTP服务器的域名,具体命令为HELO,其后为命令参数。

(4)SMTP服务器若认为身份有效,则发回应答代码250,否则发回其它代码(例如421表示服务不可用)。SMTP客户收到该应答后,使用命令MAIL FROM来告诉服务器邮件来自何方。

(5)SMTP服务器若认为合理,则发回应答代码250,否则发回其它错误代码。SMTP客户收到该应答后,使用命令RCPT TO来告诉服务器邮件去往何地。

(6)SMTP服务器中如果有该收件人邮箱,则发回应答代码250,否则发回其它错误代码。SMTP客户收到该应答后,使用DATA命令来告诉服务器自己准备发送邮件内容了。

(7)SMTP服务器如果准备好接收,则发回应答代码354,否则发回其它错误代码。SMTP客户收到该应答后,开始向服务器发送邮件内容。SMTP客户发送完邮件内容后,还要发送结束符。

(8)SMTP服务器若收件成功,则发回应答代码250,否则发回其它错误代码。SMTP客户收到该应答后,使用命令QUIT向服务器请求断开连接。

(9)SMTP服务器发回应答代码221,表示接受请求并主动断开连接。

389c6229f9ca4d8c978d0c9c26aaa62c.png

注意:

①为了简单起见,上述举例省略了认证过程。

②应答代码后面一般都跟有简单的描述信息。

③不同的SMTP服务器给出的相同应答代码的描述信息可能不同。

5、电子邮件的信息格式

(1)电子邮件的信息格式并不是由SMTP定义的,而是在RFC 822中单独定义的,这个RFC文档已在2008年更新为RFC 5322。

(2)一个电子邮件有信封和内容两部分,而内容又由首部和主体两部分构成。首部和主体的信息都需要由用户来填写。

(3)首部中包含有一些关键字,后面加上冒号,然后填上相应内容。用户写好首部后,邮件系统将自动地将信封所需的信息提取出来并写在信封上,所以用户不需要填写电子邮件信封上的信息。(To和Subject往往是必填选项)

①关键字From,冒号后面填入发件人的电子邮件地址,一般由邮件系统自动填入。

②关键字To,冒号后面填入一个或多个收件人的电子邮件地址。

③关键字Cc,冒号后面填入一个或多个收件人以外的抄送人的电子邮件地址(抄送人收到邮件后,可看可不看邮件,可回可不回邮件)。

④关键字Subject,冒号后面填入邮件的主题,它反映了邮件的主要内容。

(4)在填写完首部各关键字的内容后,用户还需要撰写邮件的主体部分,这才是用户想传递给收件人的核心信息。

63f2876e7c2d46ce90d616e989c33f6b.png

6、多用途因特网邮件扩展MIME

(1)SMTP协议只能传送ASCII码文本数据,不能传送可执行文件或其它的二进制对象,也就是说SMTP不能满足传送多媒体邮件(例如带有图片、音频或视频数据)的需要,并且许多其他非英语国家的文字(例如中文、俄文、甚至带有重音符号的法文或德文)也无法用SMTP传送。

(2)为解决SMTP传送非ASCII码文本的问题,提出了多用途因特网邮件扩展MIME(Multipurpose Internet Mail Extensions)。

(3)SMTP协议只能能传送ASCII码文本数据,假如发送方发送的电子邮件中包含有非ASCII码数据,则不能直接使用SMTP进行传送,需要通过MIME进行转换,将非ASCII码数据转换为ASCII码数据,然后就可以使用SMTP进行传送了。

(4)接收方也要使用MIME对接收到的ASCII码数据进行逆转换,这样就可以得到包含有非ASCII码数据的电子邮件。

3b68b47752df4285902de7b84e12a0db.png

(5)为了实现这种转换,MIME做出了以下改进:

①加了5个新的邮件首部字段,这些字段提供了有关邮件主体的信息。

②定义了许多邮件内容的格式,对多媒体电子邮件的表示方法进行了标准化。

③定义了传送编码,可对任何内容格式进行转换,而不会被邮件系统改变。

(6)实际上,MIME不仅仅用于SMTP,也用于后来的同样面向ASCII码字符的超文本传送协议HTTP。

7、常用的邮件读取协议

(1)邮局协议POP(Post Office Protocol):

①POP3是其第三个版本,是因特网正式标准,它是非常简单、功能有限的邮件读取协议。

②用户只能以下载并删除方式或下载并保留方式从邮件服务器下载邮件到用户方计算机,不允许用户在邮件服务器上管理自己的邮件,例如创建文件夹,对邮件进行分类管理。

(2)因特网邮件访问协议IMAP(lnternet Message Access Protocol):

①IMAP4是其第四个版本,目前还只是因特网建议标准。它是功能比POP3强大的邮件读取协议。

②用户在自己的计算机上就可以操控邮件服务器中的邮箱,就像在本地操控一样,因此IMAP是一个联机协议。

(3)POP3和IMAP4都采用基于TCP连接的客户/服务器方式,POP3使用熟知端口110,IMAP4使用熟知端口143。

8、基于万维网的电子邮件

(1)通过浏览器登录(提供用户名和口令)邮件服务器万维网网站就可以撰写、收发、阅读和管理电子邮件。这种工作模式与IMAP很类似,不同的是用户计算机无需安装专门的用户代理程序,只需要使用通用的万维网浏览器。

(2)邮件服务器网站通常都提供非常强大和方便的邮件管理功能,用户可以在邮件服务器网站上管理和处理自己的邮件,而不需要将邮件下载到本地进行管理。

(3)如下图所示,假设用户A和B都使用网易邮件服务器,用户A要给用户B发送邮件。

①用户A使用浏览器登录邮件服务器网站,撰写并发送邮件给用户B。

②用户B也使用浏览器登录邮件服务器网站,读取收到的邮件。

用户A和B在发送和接收邮件时与服务器之间都使用的是HTTP协议,而不需要使用我们之前介绍过的SMTP和POP3协议。

9f09b000144644d0823918e8b4650e56.png

(4)如下图所示,假设用户A使用网易邮件服务器,用户C使用谷歌邮件服务器,用户A要给用户C发送邮件。

用户A使用浏览器登录自己的邮件服务器网站,撰写并发送邮件给用户C,使用的是HTTP协议。

用户A的邮件服务器使用SMTP将邮件发送给用户C的邮件服务器。

用户C也使用浏览器登录自己的邮件服务器网站,读取收到的邮件使用的也是HTTP协议。

6502157f68914153abbb1610ad73a717.png

七、万维网WWW

1、万维网概述

(1)万维网WWW(World Wide Web)并非某种特殊的计算机网络,它是一个大规模的、联机式的信息储藏所,是运行在因特网上的一个分布式应用。

(2)万维网利用网页之间的超链接将不同网站的网页链接成一张逻辑上的信息网。

(3)万维网是欧洲粒子物理实验室的Tim Berners-Lee最初于1989年3月提出的。

2、浏览器

(1)相关历史:

①1993年2月,诞生了世界上第一个图形界面的浏览器Mosaic。

②1995年,著名的Netscape Navigator浏览器上市。

(2)目前比较流行的浏览器如下:(红色字为它们的渲染引擎)

a14eb1bd901b43f69f3fedb6a03f378e.png

(3)浏览器最重要的部分是渲染引擎,也就是浏览器内核,它负责对网页内容进行解析和显示。

①不同的浏览器内核对网页内容的解析也有不同,因此同一网页在不同内核的浏览器里的显示效果可能不同。

②网页编写者需要在不同内核的浏览器中测试网页显示效果。

3、万维网应用

(1)在用户主机中使用浏览器来访问湖南科技大学的万维网服务器,也就是访问湖南科技大学的官方网站。

①在浏览器的地址栏中输入湖南科技大学官方网站的域名并按下回车键后,浏览器将发送请求报文给服务器。

②服务器收到请求报文后执行相应操作,然后给浏览器发回响应报文。

③浏览器解析并渲染响应报文中的内容,这样就可以看到网站首页了。

6042a102f0334059ad4ec0120682b63b.png

(2)为了方便地访问在世界范围的文档,万维网使用统一资源定位符URL来指明因特网上任何种类“资源”的位置。

①统一资源定位符的一般形式由四个部分组成,分别是协议、主机、端口、路径

②之前在浏览器地址栏中输入的是湖南科技大学官方网站的域名,目的是获取网站首页的内容,其对应的统一资源定位符如图所示。

855cf44c935c4e3e9224b51d8abf8260.png

(3)当我们点击网页中的某个超链接时,将跳转到另一个网页,其中统一资源定位符的协议、主机和端口与网站首页相同,不同的是路径和网页文件

60aa242eca3d43e09568f98e390f11f8.png

4、万维网的文档

(1)将之前访问的湖南科技大学官方网站的首页另存为文件,可以看到有一个扩展名为htm的文件和一个文件夹,文件夹中的内容如下图所示:三个扩展名为htm的文件是HTML文档,五个扩展名为js的文件是JavaScript文档,两个扩展名为css的文件是CSS文档,其它的JPG文件和PNG文件是图片文件。

0d3486636c944ae3b74e190f67473c47.png

①超文本标记语言HTML(HyperText Markup Language):使用多种“标签”来描述网页的结构和内容。

②层叠样式表CSS(Cascading Style Sheets):从审美的角度来描述网页的样式。

③JavaScript:一种脚本语言(和Java没有任何关系),控制网页的行为。

(2)由HTML、CSS、JavaScript编写的万维网文档,由浏览器内核负责解析和渲染。

(3)下图所示是用HTML编写的最简单的HTML文档,用浏览器打开该HTML文档,浏览器会渲染出一个非常简单的网页。

①在HTML文档中,使用两个html标签来定义HTML文档的范围,在其内部使用两个head标签定义HTML文档的首部,使用两个body标签定义HTML文档的主体。

②首部中两个title标签之间的内容被渲染为网页的标题,两个p标签之间的内容被染为一个文本段落。

9ad93a60eddf4fafb7702c655666dee8.png

③HTML使用多种“标签”来描述网页的结构和内容,但是所呈现出来的内容样式过于简单,或者说不够美观,这时可以在CSS文档中定义一些所需的样式对网页显示内容进行美化。

(4)下图(上半部分)所示是一个CSS文档,在其中定义了一种样式:颜色为深粉色,字体大小为36个像素。

①在之前编写好的HTML文档的首部使用link标签将该CSS文档引入。

②将样式名称指定给主体中需要更改样式的那个p标签。

c1d678b232a3421182657f4266bb9214.png

③在浏览器中进行刷新,就可以看到浏览器重新渲染出了网页内容,可以看到,“Hello world”段落的颜色和字体大小都发生了相应的变化。

499bb47e39d74f6fad2be1ec0d78df44.png

(5)要想让用户可以在网页上进行相应操作,就需要编写JS文档。

①在之前的HTML文档的主体中使用button标签来添加一个按钮,为该按钮指定一个发生单击事件时应该调用的处理函数,然后用JavaScript脚本语言来编写一个JS文档,在该文档中编写单击事件处理函数的具体实现代码。

②在HTML文档的首部使用script标签将这JS文档引入。

③在事件处理函数中,通过元素的id来找到相应的元素,也就是显示Hello world的p标签,然后更改其显示内容。

49524aa7e99348f5a8ef5122fd1a284b.png

④在浏览器中进行刷新,就可以看到刚刚添加的按钮。用鼠标点击该按钮时,“Hello world”变成了“谢谢你的赞”。

7da3e9ea257f48faa4fdd310dd9c2b3f.png

5、超文本传输协议HTTP

(1)HTTP定义了浏览器(即万维网客户进程)怎样向万维网服务器请求万维网文档,以及万维网服务器怎样把万维网文档传送给浏览器。

(2)如下图所示,使用用户主机来访问湖南科技大学的万维网服务器,可以看成是用户主机中的浏览器进程(即客户进程)与服务器中的服务器进程基于因特网的通信。

浏览器进程首先发起与服务器进程的TCP连接,使用熟知端口号80,基于这条已建立好的TCP连接,浏览器进程向服务器进程发送HTTP请求报文

服务器进程收到HTTP请求报文后执行相应操作,然后给浏览器进程发回HTTP响应报文

4539aa58d3d445ca8df3af437c5c7d0c.png

(3)HTTP/1.0采用非持续连接方式,在该方式下,每次浏览器要请求一个文件都要与服务器建立TCP连接,当收到响应后就立即关闭连接

①客户与服务器之间通过“三报文握手”进行TCP连接,在这三个报文中的最后一个报文的数据载荷部分携带有HTTP请求报文,服务器收到后给客户发回HTTP响应报文。

②一次请求和响应所耗费的时间记为往返时间RTT,请求一个万维网文档所需的时间为2RTT+文档的传输时延。

③每请求一个文档就要有两倍的RTT的开销。若一个网页上有很多引用对象(例如图片等),那么请求每一个对象都需要花费2RTT的时间。

④为了减小时延,浏览器通常会建立多个并行的TCP连接同时请求多个对象,但是这会大量占用万维网服务器的资源,特别是万维网服务器往往要同时服务于大量客户的请求,这会使其负担很重。

a78fce14a44d417fb975039ff80d7909.png

(4)HTTP/1.1采用持续连接方式(默认采用持续连接方式,可以更改为非持续连接方式),在该方式下,万维网服务器在发送响应后仍然保持这条连接,使同一个客户(浏览器)和该服务器可以继续在这条连接上传送后续的HTTP请求报文和响应报文

①这并不局限于传送同一个页面上引用的对象,而是只要这些文档都在同一个服务器上就行。

②为了进一步提高效率,HTTP/1.1的持续连接还可以使用流水线方式工作,即浏览器在收到HTTP的响应报文之前就能够连续发送多个请求报文。这样的一个接一个的请求报文到达服务器后,服务器就发回一个接一个的响应报文,这样就节省了很多个RTT时间,使TCP连接中的空闲时间减少,提高了下载文档的效率。(下图所示的是非流水线方式)

3290f7f66113438b842cdd183a01026d.png

(5)HTTP是面向文本的,其报文中的每一个字段都是一些ASCII码串,并且每个字段的长度都是不确定的。

①HTTP请求报文格式:

[1]第一行是请求行方法字段开始,其后跟一个空格,后跟统一资源定位符字段,其后跟一个空格,后跟版本字段,最后是回车换行

[2]从第二行开始是首部行每一个首部行由首部字段名开始,其后跟一个冒号,再跟一个空格,然后是该字段的取值,最后是回车换行

[3]可以有多个首部行,如下图所示。

[4]在最后的首部行下面是一个空行

[5]在空行下面是实体主体,通常不使用。

036c3e422f06491f97fee3c520e8e9b9.png

344abf7135984286aba04171b8d2fd94.png

②HTTP响应报文的格式:

[1]第一行是状态行版本字段开始,其后跟一个空格,后跟状态码字段,其后跟一个空格,后跟短语字段,最后是回车换行

[2]除状态行外,其它部分与HTTP请求报文格式的对应部分是相似的,这里不再赘述。

63fdc684398646e1b0111c663914907f.png

7b33f20227294653aa1249d8074ca32b.png

6、Cookie

(1)在访问网站时,浏览器通常会使用Cookie在服务器上记录用户信息。

①早期的万维网应用非常简单,仅仅是用户查看存放在不同服务器上的各种静态的文档,因此HTTP被设计为一种无状态的协议。这样可以简化服务器的设计。

②现在,用户可以通过万维网实现各种复杂的应用,如网上购物、电子商务等,这些应用往往需要万维网服务器能够识别用户。

③Cookie提供了一种机制使得万维网服务器能够“记住”用户,而无需用户主动提供用户标识信息,也就是说,Cookie是一种对无状态的HTTP进行状态化的技术。

(2)Cookie的工作原理:

①如下图所示,用户主机中的浏览器进程首先与万维网服务器中的服务器进程建立TCP连接。

②当用户的浏览器进程初次向服务器进程发送HTTP请求报文时,服务器进程就会为其产生一个唯一的Cookie识别码,并以此为索引在服务器的后端数据库中创建一个项目,用来记录该用户访问该网站的各种信息。

③接着服务器进程给浏览器进程发回HTTP响应报文,在响应报文中包含有一个首部字段为Set-Cookie的首部行,该字段的取值就是Cookie识别码

④当浏览器进程收到该响应报文后,就在一个特定的Cookie文件中添加一行,记录该服务器的域名和Cookie识别码。

8c551c4805f641d9b6b48c7a1e0246c5.png

⑤当用户再次使用该浏览器访问这个网站时,每发送一个HTTP请求报文,浏览器都会从Cookie文件中取出该网站的Cookie识别码,并放到HTTP请求报文的Cookie首部行中

⑥服务器进程收到HTTP请求报文后,根据其中的Cookie识别码就可以识别出该用户,并返回该用户的个性化网页。

b1fd85e5a32249d792b7daee35d7c12a.png

7、万维网缓存与代理服务器

(1)在万维网中还可以使用缓存机制以提高万维网的效率。

(2)万维网缓存又称为Web缓存(Web Cache),可位于客户机,也可位于中间系统上,位于中间系统上的Web缓存又称为代理服务器(Proxy Server)。

(3)Web缓存把最近的一些请求和响应暂存在本地磁盘中,当新请求到达时,若发现这个请求与暂时存放的请求相同,就返回暂存的响应,而不需要按URL的地址再次去因特网访问该资源。

(4)如下图所示,右侧的是因特网上的某台万维网服务器,为了与万维网代理服务器的名称区分,简称该服务器为原始服务器;左侧的是是校园网中的某台万维网代理服务器,简称其为代理服务器。

①当校园网中的某台主机要访问因特网上的原始服务器时,它首先会向校园网中的代理服务器发送请求。

②若代理服务器中存放有所请求的对象,则代理服务器会向该主机发回包含所请求对象的响应;若代理服务器中没有所请求的对象,则代理服务器会向因特网上的原始服务器发送请求,原始服务器将包含有所请求对象的响应发回给代理服务器,代理服务器将该响应存入Web缓存,然后给主机发回该响应。

d82e5d8e651441eab2de739fa129cc56.png

③若Web缓存的命中率比较高,则路由器R1和R2之间的链路的通信量将大大减少,因而可以减少校园网各主机访问因特网的时延。

(5)假定原始服务器中有一个文档,该文档在代理服务器中有副本。

①如果原始服务器中的该文档已被更改,之后,校园网中的某台主机要请求该文档,它首先向校园网中的代理服务器发送请求,代理服务器找到该文档后,将其封装在响应报文中发回给主机。这样,主机所请求到的文档与原始服务器中的文档就不一致了。

f30009f5dc1f49f4b50d8b7f228de8c1.png

②为了解决上述问题,原始服务器通常会为每个响应的对象设定一个修改时间字段(Last-Modified)和一个有效日期字段(Expires)。

③当校园网中的某台主机要请求原始服务器中的该文档时,它首先向校园网中的代理服务器发送请求。

[1]若代理服务器中的该文档未过期,则代理服务器将其封装在响应报文中发回给主机。

[2]若代理服务器中的该文档已过期,则代理服务器会向因特网上的原始服务器发送请求。在请求报文中包合有一个首部字段为lf-modified-since的首部行,该字段的取值就是该文档的修改日期,原始服务器根据该文档的修改日期就可判断出代理服务器中存储的该文档是否与自己存储的该文档一致。

#1 如果一致,则给代理服务器发送不包含实体主体的响应,状态码为304,短语为Not Modified,代理服务器重新更新该文档的有效日期,然后将该文档封装在响应报文中发回给主机。

dd988eea93ca4896b57eb7b0c42b3c51.png

#2 如果不一致,则给代理服务器发送封装有该文档的响应报文,这样代理服务器就更新了该文档,然后将更新后的该文档封装在响应报文中发回给主机。

e2d37c7765f64b6dac828d0deefb70dc.png

猜你喜欢

转载自blog.csdn.net/Zevalin/article/details/135096652
今日推荐