本篇笔记整理:Code_流苏(CSDN)
观前提示:本篇内容为计算机网络第6章应用层全章笔记,适合入门学习以及后期复习,超详细!建议收藏学习!

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

万维网www◆ 在本章中,我们以一些经典的网络应用为例来学习有关网络应用的原理、协议和实现方面的知识。

◆ 网络应用程序运行在处于网络边缘的不同的端系统上,通过彼此间的通信来共同完成某项任务。开发一种新的网络应用首先要考虑的问题就是网络应用程序在各种端系统上的组织方式和它们之间的关系。目前流行的主要有以下两种:
1️⃣客户/服务器(C/S方式)
2️⃣对等方式(P2P方式)


◆ 动态主机配置协议DHCP(Dynamic Host Configuration Protocol)提供了一种机制,称为即插即用连网。这种机制允许一台计算机加入新网络时可自动获取IP地址等网络配置信息而不用手工参与。
1️⃣DHCP的作用
2️⃣DHCP的工作过程
3️⃣DHCP中继代理
◆ DHCP主要使用以下报文来实现其功能:
发现报文请求报文否认报文提供报文确认报文释放报文◆ DHCP报文在运输层使用UDP协议封装
DHCP客户使用的UDP端口号为68DHCP服务器使用的UDP端口号为67◆ DHCP客户在未获取到IP地址时使用地址0.0.0.0
◆ 在每一个网络上都设置一个DHCP服务器会使DHCP服务器的数量太多。因此现在是使每一个网络至少有一个DHCP中继代理(通常是一台路由器),它配置了DHCP服务器的IP地址信息,作为各网络中计算机与DHCP服务器的桥梁。
◆ 域名系统DNS是因特网使用的命名系统,用来把便于人们记忆的具有特定含义的主机名(例如www.abcd.com),转换为便于机器处理的IP地址。
◆ 因特网采用层次树状结构的域名结构

◆ 顶级域名TLD(Top Level Domain)分为以下三类:
nTLDgTLDarpa◆ 域名和IP地址的映射关系必须保存在域名服务器中,供所有其他应用查询。显然不能将所有信息都储存在一台域名服务器中。DNS使用分布在各地的域名服务器来实现域名到IP地址的转换。
◆ 域名服务器可以划分为以下四种不同的类型:
◆ 域名解析的过程使用两种域名查询方式:
1️⃣递归查询

2️⃣迭代查询

◆ 为了提高DNS的查询效率,并减轻根域名服务器的负荷和减少因特网上的DNS查询报文数量,在域名服务器和主机中广泛地使用了高速缓存。
◆ DNS报文使用运输层的UDP协议进行封装,运输层端口号为53。
◆ 将某台计算机中的文件通过网络传送到可能相距很远的另一台计算机中,是一项基本的网络应用,即文件传送。
◆ 文件传送协议FTP(File Transfer Protocol)是因特网上使用得最广泛的文件传送协议。
各计算机系统的细节,因而适合于在异构网络中任意计算机之间传送文件。在因特网发展的早期阶段,用FTP传送文件约占整个因特网的通信量的三分之一,而由电子邮件和域名系统所产生的通信量还要小于FTP所产生的通信量。只是到了1995年,万维网Www的通信量才首次超过了FTP。
◆ FTP客户和服务器之间要建立以下两个并行的TCP连接:
用于传送FTP相关控制命令。用于文件传输,在每次文件传输时才建立,传输结束就关闭。默认情况下,FTP使用TCP 21端口进行控制连接,TCP 20端口进行数据连接。但是,是否使用TCP 20端口建立数据连接与传输模式有关,主动方式使用TCP 20端口被动方式由服务器和客户端自行协商决定。

◆ 电子邮件系统采用客户/服务器方式。三个主要组成构件:用户代理,邮件服务器,以及电子邮件所需的协议。
用户代理是用户与电子邮件系统的接口,又称为电子邮件客户端软件。

邮件服务器是电子邮件系统的基础设施。因特网上所有的ISP都有邮件服务器,其功能是发送和接收邮件,同时还要负责维护用户的邮箱。


协议包括邮件发送协议(例如SMTP)和邮件读取协议(例如POP3)。

◆ 常用的邮件发送协议是简单邮件传送协议SMTP
ASCII码文本
◆ 为解决SMTP传送非ASCII码文本的问题,提出了多用途因特网邮件扩展MIME。

◆ 常用的邮件读取协议有以下两个:
邮局协议POP3:非常简单、功能有限的邮件读取协议。用户只能以下载并删除方式或下载并保留方式从邮件服务器下载邮件到用户方计算机。不允许用户在邮件服务器上管理自己的邮件。因特网邮件访问协议IMAP:功能比POP3强大的邮件读取协议。用户在自己的计算机上就可以操控邮件服务器中的邮箱,就像在本地操控一样,因此IMAP是一个联机协议。POP3和IMAP4都采用基于TCP连接的客户/服务器方式。POP3使用端口110,IMAP4使用端口143。
◆ 基于万维网的电子邮件
HTTP协议,而邮件服务器之间使用SMTP协议。
◆ 万维网WWW (Worid Wide Web)是一个大规模的、联机式的信息储藏所,是运行在因特网上的一个分布式应用。
◆ 万维网利用网页之间的超链接将不同网站的网页链接成一张逻辑上的信息网。
◆ 万维网是欧洲粒子物理实验室的Tim Berners-Lee最初于1989年3月提出的。

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

◆ 万维网使用统一资源定位符URL来指明因特网上任何种类“资源”的位置。其一般形式为:<协议>://<主机>:<端口>/<路径>

◆ 万维网文档
超文本标记语言HTML,使用多种“标签”来描述网页的结构和内容。(网页扩展名为.htm)

层叠样式表CSS,从审美角度来描述网页的样式。(文件扩展名为.css)

脚本语言JavaScript (与Java没有任何关系),控制网页的行为。(文件扩展名为.js)

(以上鸟类图片,来源于网络,此处用于帮助理解这三者的区别)
◆ 超文本传输协议HTTP (HyperText Transfer Protocol)定义了浏览器(即万维网客户进程)怎样向万维网服务器请求万维网文档,以及万维网服务器怎样把万维网文档传送给浏览器。

HTTP/1.0采用非持续连接方式。每次浏览器要请求一个文件都要与服务器建立TCP连接(80端口),当收到响应后就立即关闭连接。
两倍的RTT的开销。多个并行的TCP连接同时请求多个对象。
HTTP/1.1采用持续连接方式。万维网服务器在发送响应后仍然保持这条连接,使同一个客户(浏览器)和该服务器可以继续在这条连接上传送后续的HTTP请求报文和响应报文。为了进一步提高效率,还可采用流水线方式,即浏览器在收到HTTP的响应报文之前就能够连续发送多个请求报文。
◆ HTTP有两类报文:请求报文和响应报文。报文中的每一个字段都是一些ASCII码串,并且每个字段的长度都是不确定的。
1️⃣请求报文格式

2️⃣响应报文格式
◆ Cookie提供了一种机制使得万维网服务器能够“记住”用户。而无需用户主动提供用户标识信息。也就是说,Cookie是一种对无状态的HTTP进行状态化的技术。
◆ 在万维网加粗样式中还可以使用缓存机制以提高万维网的效率。万维网缓存又称为Web缓存,可位于客户机,也可位于中间系统上,位于中间系统上的Web缓存又称为代理服务器。
本篇笔记整理:Code_流苏(CSDN)
参考教材:谢希仁 计算机网络第七版
课件资料及视频学习:MOOC计算机网络(湖科大 高军老师)
计算机网络笔记专栏——笔记及测验练习都在这
如果对大家有帮助的话,希望大家能多多点赞+关注!这样我动力会更足哦! ღ( ´・ᴗ・` )比心。