101
TCP/IP TCP/IP 应应应应应 应应应应应 应应应 应应应 [email protected] 2013 2013 12 12 17 17

TCP/IP 应用层协议

  • Upload
    luisa

  • View
    283

  • Download
    0

Embed Size (px)

DESCRIPTION

TCP/IP 应用层协议. 陈庆章 [email protected] 2013 年 12 月 17 日. 应用层协议 DNS. 域名系统( DNS ). DNS ( RFC 1035 )也是 TCP/IP 的应用层协议之一。它利用了 UDP 传输层协议,端口为 53 。. 因特网编址机制:三种形式的地址管理机制 域名地址 : www.zjut.edu.cn 层次化的地址,便于人们记忆。 IP 地址 : 202.117.0.20 32 位逻辑编码,用来在因特网中定位主机和路由器的接口。 TCP/IP 网络上的每台主机都必须有唯一的 IP 地址。 - PowerPoint PPT Presentation

Citation preview

Page 1: TCP/IP 应用层协议

TCP/IPTCP/IP 应用层协议应用层协议TCP/IPTCP/IP 应用层协议应用层协议陈庆章陈庆章

[email protected]年年 1212月月 1717 日日

Page 2: TCP/IP 应用层协议

应用层协议应用层协议 DNSDNS应用层协议应用层协议 DNSDNS

Page 3: TCP/IP 应用层协议

域名系统( DNS )• 因特网编址机制:三种形式的地址管理机制

– 域名地址:www.zjut.edu.cn• 层次化的地址,便于人们记忆。

– IP 地址: 202.117.0.20• 32 位逻辑编码,用来在因特网中定位主机和路由器的接口。

TCP/IP 网络上的每台主机都必须有唯一的 IP 地址。• 域名地址转换到 IP 地址由域名服务系统( Domain Name

System, DNS )实现,这个转换过程又称为域名解析(Name Resolution )。

– MAC 地址: 12-FA-9B-23-DB-11• 48 位物理编码,用来在局域网中识别主机 / 路由器的接口。• IP 地址转换到 MAC 地址由地址解析协议( ARP )实现。

DNS( RFC 1035 )也是 TCP/IP 的应用层协议之一。它利用了 UDP 传输层协议,端口为 53 。

Page 4: TCP/IP 应用层协议

因特网上计算机的名字• IP 地址的优点和缺点

– IP 地址更适合计算机处理• IP 地址包含足够的路由信息。

– IP 地址不适合人们记忆– 无法通过 IP 地址猜测主机的用途

• 如一个主机到底是 www 服务器还是 FTP 服务器?• 如何取长补短——域名系统

– 域名:层次化的主机名– 域名系统:任务是将域名解析为对应的 IP 地址。– 优点:

• 使用方便,易于记忆。• 一致性好,不会随 IP 地址的改变而改变。

Page 5: TCP/IP 应用层协议

域名空间(域名树)

root

com net org edu gov mil int cn uk hk ...

ibm hp intl … 3com com edu gov … net

tsi nghua pku sj tu … fudan xj tu

www mai l f tp … bbs

根域

二级域

三级域

四级域

域名空间分为若干层次:根域(顶级域)和次级域

Page 6: TCP/IP 应用层协议

主机域名的构成• 主机名是由一系列由“ .” 分开的标签组成:

– 每个标签不能超过 63 个字符;– 全部的标签不能超过 255 个字符;– 书写顺序是从主机开始直到域名树的根域为止。

例如:• www.zjut.edu.cn• www.computer.zjut.edu.cn

• 域名是一个组织在域名空间中的名字:– 例如,浙江工大的域名为 zjut.edu.cn 。– 该组织中已注册的主机都以组织的域名为后缀。

Page 7: TCP/IP 应用层协议

DNS 系统的组织结构• DNS 是一个分布式的数据库

– DNS 使用了分布式的域名数据库,运行域名数据库的计算机称为 DNS 服务器。

• DNS 服务器以层次型结构(和域名树相对应)分布在世界各地,每台 DNS 服务器只存储了一小部分 DNS 数据。

– 每一个拥有域名的组织都必须要有 DNS 服务器,以提供自己域内的域名到 IP 地址的映射服务。

• 例如,浙江工大的 DNS 服务器为 172.14.8.9 ,它负责进行zjut.edu.cn 域内的域名和 IP 之间的转换。

– 通常每个域都有一台主 DNS 服务器,然后有一台或数台备份 DNS 服务器。

• 浙江工大的备份 DNS 服务器为 172.16.7.10 。

Page 8: TCP/IP 应用层协议

• DNS 服务器分为三类– 本地域名服务器( Local Name Server )

• 即每个组织 / 企业的 DNS 服务器。– 根域名服务器( Root Name Server )

• 为下级域名服务器提供域名解析服务;– 它需要知道全部根域名服务器(和部分二级域名服务器)的地址。

• 数量很少,由于历史原因,主要分布在北美地区。– 认证域名服务器( Authoritative Name Server )

• 每台因特网中的主机都应该在所在域的域名服务器中注册,提供注册的域名服务器就是该主机的认证域名服务器。

• 一般来说,认证域名服务器就是主机所在单位的 DNS 服务器。

DNS 服务器

Page 9: TCP/IP 应用层协议

• DNS 服务器的功能– 能够直接处理域内的域名解析请求。– 能够向其他 DNS 服务器发出查询请求来处理对

其他域的域名解析请求。– 能够缓存对其他域的域名解析请求的结果。

• DNS 服务器的操作– 如果本地域名服务器不能解析域名,它就向根域

名服务器询问;– 根域名服务器将告诉它与哪一个域名服务器联系;– DNS 再向该域名服务器进行查询;– 一个 DNS 请求可能要经过多个往返。

Page 10: TCP/IP 应用层协议

• 域名解析的例子– 某个用户要浏览浙江工大的主页,用户主机(假定为 A )必须获得

www.zjut.edu.cn 主机(以下简称为 zjut )的 IP 地址。解析过程:• A 向本地域名服务器 DNS1 查询请求;• 如果 DNS1 上有 zjut 的记录,就立即将 JD的 IP 地址返回给A ;

• 如果 DNS1 上没有 zjut 的记录, DNS1 就会向根域名服务器发出查询请求;

• 根域名服务器把负责 cn 域的域名服务器 B的 IP 地址告诉给DNS1 ;

• DNS1向 B 查询,获得负责 edu.cn域 DNS 服务器 C 的地址;• DNS1向 C 查询,获得负责 zjut.edu.cn域 DNS 服务器 D 的

地址;• DNS1向 D 查询,即可获得 www.zjut.edu.cn的 IP 地址。• (注:在命令行下可用 nslookup 命令进行 DNS 查询)

Page 11: TCP/IP 应用层协议

域名数据库中的记录类型• A 记录( Address 记录)

– A 记录是用来指定域名对应的 IP 地址。---最常用

• NS 记录(Name Server 记录)– 域名服务器记录,用来指定该域名由哪个 DNS 服务器来进行解析。

• 别名记录( CNAME 记录)– 这种记录用于将多个名字映射到同一台计算机。 通常用于同时提供 WWW、

FTP和MAIL 服务的计算机。 [例 ]• MX 记录(Mail Exchanger 记录)

– 邮件交换记录,它指向一个邮件服务器,用于电子邮件系统发邮件时根据收信人的地址后缀来定位邮件服务器。 [ 例 ]

• PTR 记录– 域名指针记录,用于反向 DNS 查找。例如,要查找 202.117.0.20 的域名时就需要借助于 PTR 记录。

• SOA 记录——用于说明一个 DNS 系统的基本信息

例如,一台名为“ abc.mydomain.com”( A 记录)的计算机, 它同时提供WWW和MAIL 服务,为了便于用户访问服务,可以为该计算机设置两个别名( CNAME ): WWW和MAIL 。 这两个别名的全称就是“ www.mydomain.com” 和“ mail.mydomain.com” ,实际上它们都指向“ abc.mydomain.com” 。

例如,当 Internet 上的某用户要发一封信给 [email protected] 时,该用户的邮件系统通过 DNS 查找mail.mydomain.com 这个域名的MX 记录,如果 DNS 系统查找到该MX 记录, 用户计算机就将邮件发送到 MX 记录所指定的邮件服务器上。

Page 12: TCP/IP 应用层协议

应用层协议应用层协议 TelnetTelnet应用层协议应用层协议 TelnetTelnet

Page 13: TCP/IP 应用层协议

什么是 Telnet ?• Telnet是 Telecommunication Network Protocol

的英文缩写。– 用户在本地发出命令,通过 IP 网络,进入另一台机器的系统,

这个过程即称为远程登录。• 用户通过本地计算机登录到其他计算机上,本地计算

机就成为了那台计算机的“终端”,与那台机器本身的终端享有同样的待遇,在它的权限范围内操作那台计算机。

• 大多数提供远程登录的目标系统以 UNIX 为主。• 注意:远程登录中的“远”字并非指距离,而是指不是从本地登录到这

台计算机。

Page 14: TCP/IP 应用层协议

远程终端协议 TELNET

• TELNET 是一个简单的远程终端协议,也是因特网的正式标准。

• 用户用 TELNET 就可在其所在地通过 TCP 连接注册(即登录)到远地的另一个主机上(使用主机名或 IP 地址)。

• TELNET 能将用户的击键传到远地主机,同时也能将远地主机的输出通过 TCP 连接返回到用户屏幕。这种服务是透明的,因为用户感觉到好像键盘和显示器是直接连在远地主机上。

Page 15: TCP/IP 应用层协议

客户服务器方式• 现在由于 PC 机的功能越来越强,用户已较少

使用 TELNET 了。• TELNET 也使用客户服务器方式。在本地系统

运行 TELNET 客户进程,而在远地主机则运行 TELNET 服务器进程。

• 和 FTP 的情况相似,服务器中的主进程等待新的请求,并产生从属进程来处理每一个连接。

Page 16: TCP/IP 应用层协议

网络虚拟终端 NVT 格式

–Telnet Server

–Username:–Password:

–Internet

–中国–浙江工业大

–美国–加州大

学U N I V E R S I T YU N I V E R S I T Y

Page 17: TCP/IP 应用层协议

网络虚拟终端 NVT 格式

• 客户软件把用户的击键和命令转换成 NVT 格式,并送交服务器。

• 服务器软件把收到的数据和命令,从 NVT 格式转换成远地系统所需的格式。

• 向用户返回数据时,服务器把远地系统的格式转换为 NVT 格式,本地客户再从 NVT 格式转换到本地系统所需的格式。

Page 18: TCP/IP 应用层协议

TELNET 定义的一些控制命令

(1) DO ( 选项代码 ) 表示要求对方执行该选项 WILL ( 选项代码 ) 同意执行此选项(2) DO ( 选项代码 ) 表示要求对方执行该选项 WON'T ( 选项代码 ) 不同意,状态不变(3) WILL ( 选项代码 ) 表示我想执行该选项 DO ( 选项代码 ) 同意执行此选项(4) WILL ( 选项代码 ) 表示我想执行该选项 DON'T ( 选项代码 ) 不同意,状态不变 WON'T ( 选项代码 ) 证实状态不变

Page 19: TCP/IP 应用层协议

如何使用 Telnet• 启动 telnet 客户端程序

telnet [remote-system] [port-number]

– 其中• telnet : 命令名。注意也有别的名称,如 NVT220 等。• remote-system :目标主机名 ( 域名 ) 或目标主机的 IP 地址。• port-number : 端口号。它用于标识服务器上的 telnet 服务 程序进程。 telnet 的默认端口号是 23 。

• telnet 的内部命令行提示符为: telnet>

Page 20: TCP/IP 应用层协议

•启动客户程序例( UNIX/Win DOS )–启动时直接指明要连接的目标主机 $telnet www.zjut.edu.cn 指明目标主机名 $telnet 202.117.35.70 指明目标主机 IP 地址–启动时不指明目标主机 $telnet

• 这时将进入 telnet 内部命令状态telnet> 内部命令提示符

• 在内部命令状态下键入 open命令连接远程主机 telnet>open towel.blinkenlights.nl( 星球大战 )

telnet>open forum.byr.edu.cn (北邮论坛)

Page 21: TCP/IP 应用层协议

• 连接时远程主机将要求用户输入用户名和口令 login:<user-id > password:<password >

– 如果通过了用户认证,用户就可以像在远程主机的终端上一样操作远程主机了。

– 在远程主机(服务器)提示符下,用户可以在本地计算机上输入远程系统命令,如 email、 lynx、 pico、 ls、pwd 等。

• 断开与远程主机的连接– 在远程系统提示符下键入命令: exit, logout或

Ctrl-D

Page 22: TCP/IP 应用层协议

一些可以访问的网站Bulletin Board Name

Telnet Address LocationBBS

SoftwareType

Nodes

Pay

  Dragon's Keep

dragonskeep.isasecret.com 

Kapolei, HI USA 

Worldgroup 

General 

64  Opt 

  Minions of Death

BBS

bbs.minionsofdeath.net 

Jonesboro, AR USA 

Synchronet 

General 

10  No 

  Network 23

network23.ch  Basel,

Switzerland 

Synchronet 

General 

50  No 

  Physics BBS

phybbs.dyndns.org  Las Vegas,

NV USA Renegade 

General 

6  No 

  Stages BBS

stagesbbs.com  Valley

Stream, NY USA 

Worldgroup 

General 

10  Opt 

  TheBBS weirdo.dyndns.org  Atlanta, GA USA 

Custom/Unix 

General 

-  No 

Page 23: TCP/IP 应用层协议

应用层协议应用层协议 SMTPSMTP应用层协议应用层协议 SMTPSMTP

Page 24: TCP/IP 应用层协议

电子邮件( E-mail )• 电子邮件是因特网上最典型的服务之一:• 电子邮件系统的组成

– 用户代理( User Agent )• 功能:编辑、发送、接收、阅读和管理电子邮件。• 常见的用户代理有:

– Outlook、 Outlook Express、 Foxmail 等。– 邮件服务器( E-mail Server )

• 功能:类似“邮局”,接收和转发电子邮件,向发信人报告邮件发送状态

•按照客户服务器方式工作– 既是客户,又是服务器

Page 25: TCP/IP 应用层协议

电子邮件协议

• 发送 / 转发邮件:– SMTP ( Simple Mail Transfer Protocol ) [RFC

821、 822]– MIME ( Multipurpose Internet Mail Extension) [RFC 1521]

•读取邮件:– POP3( Post Office Protocol) [RFC 1939]– IMAP4 ( Internet Message Access Protocol )

[RFC 2060

Page 26: TCP/IP 应用层协议

点击观看

电子邮件发送和接收过程

InternetE-mail Server

SMTP

发送邮件

发送邮件队列 接收端用户邮箱

SMTP

User Agent

接收邮件POP3

E-mail Server

User Agent

OutlookFoxMail

OutlookFoxMail

–TCP 连接–TCP 连接 –TCP 连接

–TCP 连接

发信人运行用户代理编辑邮件。

–发件人的邮件服务器 –收件人的邮件服务器

发送端邮件服务器收到邮件后,将邮件放入邮件缓存队列,等待发送。

发送端邮件服务器中的 SMTP 客户进程发现邮件队列中有待发送的邮件,就与接收端邮件服务器建立 TCP连接。

发送端的 SMTP 客户进程使用 SMTP 协议把邮件队列中的邮件发送给接收端的 SMTP服务进程。 发送完后,关闭TCP 连接。

接收端邮件服务器将收到的邮件放入收件人的邮箱中。

收件人收信时,运行用户代理,用户代理使用 POP3 协议将用户邮箱中的邮件下载到本地计算机。

用户代理利用 SMTP 协议将邮件传送给发件人的邮件服务器。

Page 27: TCP/IP 应用层协议

电子邮件地址• 电子邮件用户必须有一个电子邮件地址

– 许多网站提供免费电子邮件服务,需要的话可到这些网站上申请一个邮箱(电子邮件地址)。

• 电子邮件地址由两部分组成:– 用户名– 邮箱所在的邮件服务器的主机域名

• 用户名和邮件服务器域名之间用“ @”隔开 用户名 @ 邮件服务器域名– 例如:

[email protected][email protected]

Page 28: TCP/IP 应用层协议

• SMTP 是因特网上通用的电子邮件传输协议。它的特点是简单明了,容易实现。

• SMTP 定义了邮件格式及如何通过 TCP 连接传输邮件。• SMTP 使用 25号端口在两个邮件服务器之间建立 TCP 连

接。• SMTP 协议由两个文档进行描述:

– RFC821 :描述了邮件服务器之间如何转发邮件;– RFC822 :定义邮件信息的格式。

• SMTP 规定邮件的全部内容(包括附件)——无论是什么类型的数据——都必须转换成 7 位 ASCII 码进行传输。

简单邮件传输协议 SMTP

Page 29: TCP/IP 应用层协议

邮件格式 [RFC822]

• 标准的电子邮件信息由两部分组成:– 邮件头( header ):相当于“信封”,主要包括

•收件人地址•投递日期•邮件主题• 发件人地址

– 邮件体( body ):邮件正文,相当于装在信封内的信。• 邮件格式的例子

Page 30: TCP/IP 应用层协议

Received: from web10905.mail.yahoo.com (unknown [216.136.131.41])by 192.168.30.102 (Coremail) with SMTP id XQEAACPEeD3FAIMp.1for <[email protected]>; Fri, 06 Sep 2004 23:05:16 +0800 (CST)

Message-ID: <[email protected]>

Received: from [67.242.159.232] by web10905.mail.yahoo.com via HTTP; Fri, 06 Sep 2004 08:11:04 PDT

Date: Fri, 6 Sep 2004 08:11:04 -0700 (PDT)From: Joy Li <[email protected]>Subject: ThanksTo: ChenWenge <[email protected]>Cc: [email protected]: <3D3E0442.00000A.11363@smtp>MIME-Version: 1.0Content-Type: text/plain; charset=us-ascii

陈老师:我的第一次作业在附件中,请批阅。

李思 012345678 文学 21 班

Page 31: TCP/IP 应用层协议

邮件头信息都由一些关键词引导。邮件正文则没有任何关键词引导,正文是用户编辑邮件时输入的。邮件头中的一些主要关键词的含义是:Received :接收邮件的路径、日期、时间以及邮件代理程序的版本号。 From :表示邮件发送者,包括邮件地址和发送方的“真实姓名”。 Date :发信时间。Message-ID :由传输代理分配给该邮件的唯一标识。 To :收件人的电子邮件地址。 Subject :邮件主题,是发件人写的,告诉收件人该邮件的目的。Content-type :邮件正文的类型,是文本还是 MIME 格式。 Cc :表示抄送,它是“ Carbon copy” 的缩写,意为“复写副本”, 它用来指定那些将收到该邮件副本的人的邮件地址。

Page 32: TCP/IP 应用层协议

SMTP 通信• 支持 SMTP 协议的邮件服务器之间采用客户 / 服务

器方式工作,连接发起方称为客户,接收方称为服务器。一旦连接建立,邮件服务器之间通过 SMTP协议进行对话,完成邮件的转发功能。

• SMTP 定义了几个非常简单的命令用来进行邮件的发送,其中包括:– HELO– MAIL FROM– RCPT TO– DATA– QUIT

Page 33: TCP/IP 应用层协议

下面是一个用 Telnet 进行 SMTP 协议对话的例子: $ Telnet mail.zjut.edu.cn 25 Trying 202.117.1.21... Connected to mail.zjut.edu.cn. Escape character is '^]'. 220 ESMTP ready [202.117.35.70/unknown] HELO < 任意消息 > 250 < 应答信息 > MAIL FROM : <[email protected]> 250 OK RCPT TO : <[email protected]> 250 OK DATA 354 go ahead This is a test message. Be sure is send by Telnet. . 250 OK: has queued QUIT 221 close connection Connection closed by foreign host.

–TCP–连接

–SMTP–握手

–邮–件–传–送

–断开–连接

–// 连接到 email 服务器的 25端口

Page 34: TCP/IP 应用层协议

SMTP 的特点• 电子邮件无论内容多少(包括附件),均

使用一个报文( Message )发送。• 所有的邮件内容,必须使用 ASCII 代码传送。

• 所有的二进制文件内容必须使用 MIME 格式转换成 ASCII 代码(膨化处理)。

Page 35: TCP/IP 应用层协议

邮件读取协议• 常用的有: POP3和 IMAP• POP3 (邮局协议)

– 基于 TCP 协议– 客户 / 服务器方式

• 客户端程序( Outlook Express、 Foxmail 等)• 服务器程序( Exchange 等)• 客户与服务器建立 TCP 连接后才能读取邮件

– 功能:• 为用户提供邮箱• 保存收到的邮件• 把邮件传输给用户(邮件在客户端脱机处理)

– 邮件传输给用户后, POP 服务器一般不再保留

Page 36: TCP/IP 应用层协议

• IMAP (因特网报文存取协议)– 基于 TCP 协议(同 POP3 )– 客户 / 服务器方式(同 POP3 )– 功能

• 为用户提供邮箱•保存收到的邮件• 用户可直接操纵 IMAP 服务器上自己的邮件文件夹

– 新建分类文件夹,移动邮件,删除邮件,查找邮件等•仅需要打开邮件时,邮件才传输到客户端

– 邮件将一直保存在 IMAP 服务器上,除非用户明确地发出删除命令

– 典型例子: Web Mail

Page 37: TCP/IP 应用层协议

常用客户端软件

• Outlook• Foxmail

Page 38: TCP/IP 应用层协议

应用层协议应用层协议 FTPFTP应用层协议应用层协议 FTPFTP

Page 39: TCP/IP 应用层协议

文件传输( FTP )• FTP 是什么?

– FTP是 File Transfer Protocol 的英文缩写,即“文件传输协议”。

– 用于在计算机之间传送文件• 把文件从本地主机传送到远程主机称为“上载”

– Upload, Put• 把文件从远程主机传送到本地主机称为“下载”

– Download, Get

• FTP 可以传输各种类型的文件:– 文本文件( ASCII )、二进制文件( Binary );– 压缩文件、非压缩文件。

• 登录 FTP 服务器的用户需要注册才能登录,但有的FTP 服务器也允许匿名( Anonymous )登录。

Page 40: TCP/IP 应用层协议

–Softwar

e、

Program–Doc

uments

–Video, Aud

io

–ftp ftp.zjut.edu.cn

–Username: anonymous

–Password: [email protected]

–匿名登录 FTP

–Anonymous FTP Server

–ftp.zjut.edu.cn

Page 41: TCP/IP 应用层协议

FTP 工作原理• FTP 基于 TCP 协议,使用 TCP 协议实现文件的传输。

• FTP 以客户 / 服务器方式工作:– FTP 客户程序,如 Cuteftp 等,运行在用户计算

机上• 用户通过它发出传输文件的请求

– FTP 服务程序,如 Serv-U 等,运行在服务器上• 接收并响应客户程序的请求,把指定的文件发送到客户端

Page 42: TCP/IP 应用层协议

• 在进行文件传输时, FTP 的客户和服务器之间要建立两个 TCP 连接:– 控制连接( Control Connection ):

•客户程序与 FTP 服务器的端口 21建立控制连接 , 并在整个 FTP 会话过程中维持连接;

•控制连接用于传输请求和应答信息;•由 FTP 客户端发起控制连接。

– 数据连接( Data Connection ):• 数据连接用于传输文件;• 每传输一个文件都要建立一个数据连接(在 FTP 服务

器的端口 20 );•由 FTP 服务器发起数据连接。

Page 43: TCP/IP 应用层协议

–TCP

–数据传送 –控制

–FTP 客户端

–TCP

–数据传送–控制

–FTP 服务器端

–X –21

–因特网

–20–Y

–由客户端发起

–由服务器端发起

Page 44: TCP/IP 应用层协议

FTP 的文件传输过程• 建立控制连接(客户端发起)( 1 ) 客户端发送一个 TCP SYN( TCP 同步)包给服务

器端,目的端口为 21 ,源端口为一个临时端口; ( 2 )服务器端发送 SYN ACK (同步确认)包给客户端,源端口为 21 ,目的端口为客户端上使用的临时端口;( 3 )客户端发送一个 ACK (确认)包。– 控制连接建立后,客户端使用这个连接来发送 FTP 命令,

服务器端使用这个连接来发送 FTP 应答。

Page 45: TCP/IP 应用层协议

• 建立数据连接– 当用户发出一个文件传输请求时,客户端软件通过控制连接向服务器发出一个 PORT 命令,在 PORT 命令中指定一个临时端口,目的是希望服务器在建立数据连接时使用这个临时端口; ( 1 )服务器端发送一个 SYN 包给客户端,源端口为 20 ,目的端口为客户端在 PORT 命令中指定的临时端口;( 2 )客户端发送一个 SYN ACK 包,源端口为临时端口,目的端口为 20 ;( 3 )服务器端发送一个 ACK 包。

• 文件传输 – 数据连接建立后,发送数据的一方使用这个连接把文件

传送给对方。

Page 46: TCP/IP 应用层协议

• 断开数据连接– 当数据传输完成后:( 1 )发送数据的主机发出一个 FIN 命令来结束数据连接;( 2 )接收方以 ACK 确认;( 3 )接收方紧接着也发送一个 FIN 命令;( 4 )发送数据的主机以 ACK 确认。

• 断开控制连接– FTP 会话结束后:( 1 )客户端以 FIN 命令来关闭控制连接( 2 )服务器端以 ACK 确认;( 3 )服务器端发送一个 FIN ;( 4 )客户端以 ACK 确认。

Page 47: TCP/IP 应用层协议

ftp Client ftp Server

TCP:21 控制连接初始化 , 控制端口 SYN

Port xxxx ----------------------> Port 21 SYN, ACKPort xxxx <---------------------- Port 21 ACKPort xxxx ----------------------> Port 21

控制操作 : 用户列目录或传输文件 Port, IP, Port yyyy Port xxxx ----------------------> Port 21 Port Successful Port xxxx <---------------------- Port 21 List, Retr or Stor Port xxxx ----------------------> Port 21

TCP:20 数据连接初始化 , 数据端口 SYNPort yyyy <---------------------- Port 20 SYN, ACKPort yyyy ----------------------> Port 20 ACKPort yyyy <---------------------- Port 20

数据操作 : 数据传输 DataPort yyyy <---------------------> Port 20

……

Page 48: TCP/IP 应用层协议

FTP 的基本命令• 启动 FTP

– FTP [host]

例如: %ftp ftp.zjut.edu.cn (或 ftp>open ftp.zjut.edu.cn ) username : cw024001001 实名登录 password : ****** 或: username : anonymous 匿名登录 password : [email protected]

Page 49: TCP/IP 应用层协议

( 1 )帮助命令组– 列出所有的 ftp 命令

• ftp>?• ftp>help

– 列出某个 ftp 命令的使用说明• 例如:列出 open 命令的使用说明

– ftp>help open

( 2 )连接命令组– ftp>open host 连接远程主机– ftp>close 结束当前连接,不退出 ftp– ftp>disconnect 结束当前连接,不退出 ftp– ftp>bye 终止所有连接,退出 ftp– ftp>quit 终止所有连接,退出 ftp

Page 50: TCP/IP 应用层协议

( 3 )目录操作与列表命令组– ftp>pwd 列出当前目录名– ftp>cd 进入下一级目录– ftp>cdup 退回上一级目录– ftp>ls [remote-dir] [local-file] 将远程目录中文件

列表存入本地文件中 – ftp>mls remote-file local-file 将远程目录中指

定类型的文件列表存入本地文件中• 例如,要将后缀为 txt 的文件列表存入 dirfile.list 文件: ftp>mls *.txt dirfile.list

– ftp>nlist - 排序方法 [remote-dir] [local-file] 将远程目录中的文件列表按时间( rt )或字符顺序( rc )存入本地文件。

• 例如: ftp>nlist -rt /disk1/test test.list

Page 51: TCP/IP 应用层协议

( 4 )文件传输命令组– 上传文件

• ftp>put local-file [remote-file] – 若不指定远程文件名,则远程文件名同本地文件名

• ftp>send local-file [remote-file]• ftp>append local-file [remote-file]• ftp>mput local-file 一次上传多个文件

– 下载文件• ftp>get [local-file] remote-file

– 若不指定本地文件名,则本地文件名同远程文件名• ftp>recv [local-file] remote-file• ftp>reget [local-file] remote-file

– 从远程重新下载文件,参数同 get

• ftp>mget remote-file 一次下载多个文件

Page 52: TCP/IP 应用层协议

文件传输功能图

–FTP Client

–FTP Server

–put mput

–get mget–recv reget

–send append

Page 53: TCP/IP 应用层协议

( 5 )文件类型操作命令组– ftp>ascii 设置传输文件的类型为文本– ftp>binary 设置传输文件的类型为二进制

( 6 )文件属性操作命令组– ftp>chmod mode remote-file

• 设置文件权限,权限由 mode规定• 例如: ftp>chmod 666 aa 使同组用户和其他用户都有读写权

( 7 )查看文件内容命令– ftp>get filename -

• 只显示远程文件 filename 的内容, -代表本地

( 8 )其他– rename、 delete,mdelete, size,……

Page 54: TCP/IP 应用层协议

FTP 使用举例下例左边编号 [01]~[15] 是后加的。用户的输入部分用带下划线的蓝色斜体字表示。[01] ftp ftp.zjut.edu.cn[02] Connected to vineyard.zjut.edu.cn.

[03] 220 vineyard.zjut.edu.cn FTP server (Version wu-2.5.0(1) Tue Jul 13 10:20:43 CDT.

[04] Name (ftp.zjut.edu.cn:teng): anonymous[05] 331 Guest login ok, send your complete e-mail address as password.

[06] Password: [email protected][07] 230 Guest login ok, access restrictions apply.

[08] ftp>cd /pub/rfc[09] 250 CWD command successful.

[10] ftp>get rfc959.txt ftpinfo[11] 200 PORT command successful.

[12] 150 Opening ASCII mode data connection for rfc959.txt (147316 bytes).

[13] 226 Transfer complete.

local: ftpinfo remote: rfc959.txt

151249 bytes received in 2.1 seconds (71.27 Kbytes/s)

[14] ftp>quit[15] 221-You have transferred 151249 bytes in 1 files.

221-Total traffic for this session was 152964 bytes in 1 transfers. 221-Thank you for using the FTP service on vineyard.zjut.edu.cn.

221 Goodbye.

Page 55: TCP/IP 应用层协议

例子中各行信息的解释如下:[01] 用户输入 FTP 命令启动本地 FTP 客户程序和远地主机浙江工大匿名 FTP 服务器( ftp.zjut.edu.cn )建立连接。

[02] 本地 FTP 客户程序显示的连接成功的信息。[03] 远地服务器返回的信息,“ 220” 表示“服务就绪”。[04] 本地 FTP 提示用户输入用户名。输入“ anonymous” 表示请求匿名 FTP 服务。[05] 远地服务器提示“用户名正确”,需要口令。[06] 本地 FTP 提示用户输入口令。用户可以输入自己的邮件地址,例

如“ [email protected]” 。[07] 服务器返回“ 230” 提示信息,表示用户注册成功。[08]“ftp>”是 FTP 的命令提示符。用户可以输入相应的命令,如“ help”,“dir” 等。这里是改变目录“ cd”到 RFC 文件所在的目录。

[09] 远地服务器返回信息,表示改变目录命令已经成功。“ CWD” 代表“ Change Working Directory” 。

[10] 用户要求获得名为“ rfc959.txt” 的文件,并改名为“ ftpinfo” 。[11] 远地服务器提示“ PORT” 信息,表示要建立数据连接。“ 200” 表示命令正确。[12] 数字“ 150” 表示“文件状态正确,正在建立数据连接,并进行文件传输”。[13] 数字“ 226” 表示“数据传输完毕,释放数据连接”。[14] 用户输入退出命令。[15] 远地服务器表示 FTP工作结束。

Page 56: TCP/IP 应用层协议

常用 FTP 客户程序• 图形界面下的 FTP 程序简化了操作,只要用鼠标点击即可,但执行流程与上述介绍类似。 Windows环境下的 FTP 传输软件包括:– WS_FTP、 CuteFTP、 LeapFTP、 LeechFTP、……

• 不论在什么界面下进行 FTP 操作,以下要素都是必须的: 主机地址: IP 地址或主机名(域名) 登录方式:实名或匿名 用户标识:用户名或 anonymous 用户口令: xxxxxx 或 [email protected] 本地工作目录 远程工作目录

Page 57: TCP/IP 应用层协议

图形界面下的FTP(cuteftp)

Page 58: TCP/IP 应用层协议

4.4 文件传输协议( FTP )

Page 59: TCP/IP 应用层协议

一些 FTP 网站• ftp.oracle.com/   甲骨文。• ftp.novell.com/  SUSE-Linux 听说过吗?• ftp.apple.com/   苹果的 ftp ftp.sun.com/     sun 来了,其实什么也没有!• ftp.cisco.com/   思科,进去看看也好啊!• ftp://202.115.112.29 光华影院 有很多电影、音乐、工具• ftp://202.112.94.136 北京师范大学 有音乐、游戏、软件,好象没有

电影• ftp://162.105.106.11 音乐、游戏、电影、软件、书 、 MTV • ftp://ftp.cdut.edu.cn/ 山东大学英语学习 ftp • ftp://ftp.hagongda.com/ 哈尔滨工业大学• ftp://vod.zzia.edu.cn 东北师大• ftp://ftp.microsoft.com/ 微软 FTP 网站

Page 60: TCP/IP 应用层协议

应用层协议应用层协议 HTTPHTTP应用层协议应用层协议 HTTPHTTP

Page 61: TCP/IP 应用层协议

万维网( WWW )•万维网基本概念

– 浏览器( Browser )是用来解释Web页面并完成相应转换和显示的程序。

– 浏览器通过 Web页面来进行信息的传递和交流。– Web页面是用超文本标记语言编写的文档, Web页中包括文字、图像、声音、动画、视频等各种多媒体信息,也包括用超文本或超媒体表示的链接。

– 主页是进入一个网站首先看到的页面,是一个网站的脸面。

Page 62: TCP/IP 应用层协议

万维网基本概念

– 超文本( Hypertext ):是指可以链接到其他文档的文字。从页面上看超文本也是一般的文字描述,但它包含了到其他文档或同一文档不同部分的链接( Link) 或。

– 超媒体( Hypermedia ):通过图形来完成的链接,或指通过链接可以获得多媒体信息或播放多媒体信息。

– 超级链接( Hyperlink) :非线性阅读

Page 63: TCP/IP 应用层协议

万维网基本概念– Web 服务器:Web 页面并向浏览器提供服务

的服务器。目前应用最广的是 APACHE 。– 超文本标记语言 (Hypertext Markup

Language, HTML) :编写 Web 页面的标准语言。它是通过标记来对 Web 文档的格式及链接进行定义的一系列规定。

– 超文本传输协议( Hypertext Transport Protocol, HTTP ):浏览器和 Web 服务器之间的通信协议。

Page 64: TCP/IP 应用层协议

HTTP 的特点•以 Client/Server模型为基础。 HTTP 支持客户与服务器之间通信及相互传送数据,一个服务器可以为分布在世界各地的许多客户服务。

• 简易性。 HTTP被设计成一个非常简单的协议,客户机要连接到服务器,只需发送请求方式和 URL 路径等少量信息,即可得到服务器的应答。

Page 65: TCP/IP 应用层协议

HTTP 的特点• 灵活性与内容—类型 (content-type) 标

识。 HTTP 允许任意类型数据的传送,因此可以利用 HTTP 传送任何类型的对象。内容—类型标识指示了所传输数据的类型。

• “ 无连接”性。这意味着每次连接只处理一个请求。客户要建立连接需先发出请求,收到响应,然后断开连接,这实现起来效率十分高。采用这种“无连接”协议,在没有请求提出时,服务器就不会在那里空闲等待。

Page 66: TCP/IP 应用层协议

HTTP 的特点• 无状态性。这既是优点也是缺点。

– 由于无须记忆状态使得 HTTP累赘少,系统运行效率高,服务器应答快;

– 由于没有状态,协议对事务处理没有记忆能力,若后续事务处理需要有关前面处理的信息,那么这些信息必须在协议外面保存;

– 缺少状态意味着所需的前序网页信息必须保留和交换,导致每次连接需要传送较多的信息。

Page 67: TCP/IP 应用层协议

HTTP 的特点•元信息 (Meta Information) 。

– 元信息被称为是“关于信息的信息”,元信息允许服务器提供所发送数据的信息。• 例如, HTTP 可以提供所发送的对象的语言和类型。收到数据的浏览器可以根据元信息确定服务器发来的是什么内容,预料有多少数据,确知是否接收到完整的数据,以及发送过程中是否有错。

– 元信息的引入大大扩充了 HTTP 协议的功能。

Page 68: TCP/IP 应用层协议

万维网高速缓存 (Web

cache)

• 万维网高速缓存代表浏览器发出 HTTP 请求,因此又称为代理服务器 (proxy server) 。

• 万维网高速缓存将最近的一些请求和响应暂存在本地磁盘中。

• 当与暂时存放的请求相同的新请求到达时,万维网高速缓存就把暂存的响应发送出去,而不需要按 URL 的地址再去因特网访问该资源。

Page 69: TCP/IP 应用层协议

使用高速缓存可减少访问因特网服务器的时延

–校园网

–源点服务器

–2 Mb/s–因特网

–浏览器 –R1 –R2

–这条链路上–的时延很大

–没有使用高速缓存的情况

–所有万维网通信量–都经过这条链路

Page 70: TCP/IP 应用层协议

使用高速缓存的情况

–校园网

–校园网的高速缓存–(代理服务器)

–源点服务器

–2 Mb/s –因特网–浏览器 –R1 –R2

–(1) 浏览器访问因特网的服务器时,要先与校园网的高速缓存建立 TCP 连接,并向高速缓存发出 HTTP 请求报文

Page 71: TCP/IP 应用层协议

使用高速缓存的情况

–校园网

–校园网的高速缓存–(代理服务器)

–源点服务器

–2 Mb/s –因特网–浏览器 –R1 –R2

–(2) 若高速缓存已经存放了所请求的对象,则将此对象放入 HTTP 响应报文中返回给浏览器。

Page 72: TCP/IP 应用层协议

使用高速缓存的情况

–校园网

–校园网的高速缓存–(代理服务器)

–源点服务器

–2 Mb/s –因特网–浏览器 –R1 –R2

–(3) 否则,高速缓存就代表发出请求的用户浏览器,与因特网上的源点服务器建立 TCP 连接,并发送 HTTP 请求报文。

Page 73: TCP/IP 应用层协议

使用高速缓存的情况

–校园网

–校园网的高速缓存–(代理服务器)

–源点服务器

–2 Mb/s –因特网–浏览器 –R1 –R2

–(4) 源点服务器将所请求的对象放在 HTTP 响应报文中返回给校园网的高速缓存。

Page 74: TCP/IP 应用层协议

使用高速缓存的情况

–校园网

–校园网的高速缓存–(代理服务器)

–源点服务器

–2 Mb/s–因特网

–浏览器 –R1 –R2

–(5) 高速缓存收到此对象后,先复制在其本地存储器中(为今后使用),然后再将该对象放在 HTTP 响应报文中,通过已建立的 TCP 连接,返回给请求该对象的浏览器。

Page 75: TCP/IP 应用层协议

HTTP 的报文结构

HTTP 有两类报文:• 请求报文——从客户向服务器发送请求报文。• 响应报文——从服务器到客户的回答。• 由于 HTTP 是面向正文的 (text-oriented) ,

因此在报文中的每一个字段都是一些 ASCII 码串,因而每个字段的长度都是不确定的。

Page 76: TCP/IP 应用层协议

HTTP 的报文结构(请求报文)

–方 法 –URL –版 本–首部字段名

–首部行–: –值

–首部字段名 –值

–:

– …

–实体主体–(通常不用)

–请求行

–空格 –回车换行

–:

–CRLF

–CRLF

–CRLF

–CRLF

–报文由三个部分组成,即开始行、首部行和实体主体。–在请求报文中,开始行就是请求行。

–开始行

Page 77: TCP/IP 应用层协议

HTTP 的报文结构(请求报文)

–方 法 –URL –版 本–首部字段名

–首部行–: –值

–首部字段名 –值

–:

– …

–实体主体–(通常不用)

–请求行

–空格 –回车换行

–:

–CRLF

–CRLF

–CRLF

–CRLF

–“方法”是面向对象技术中使用的专门名词。所谓“方法”就是对所请求的对象进行的操作,因此这些方法实际上也就是一些命令。因此,请求报文的类型是由它所采用的方法决定的。

Page 78: TCP/IP 应用层协议

HTTP 请求报文的一些方法

方法(操作) 意义OPTION 请求一些选项的信息GET 请求读取由 URL 所标志的信息HEAD 请求读取由 URL 所标志的信息的首部POST 给服务器添加信息(例如,注释)PUT 在指明的 URL 下存储一个文档DELETE 删除指明的 URL 所标志的资源TRACE 用来进行环回测试的请求报文CONNECT 用于代理服务器

Page 79: TCP/IP 应用层协议

HTTP 的报文结构(请求报文)

–方 法 –URL –版 本–首部字段名

–首部行–: –值

–首部字段名 –值

–:

– …

–实体主体–(通常不用)

–请求行

–空格 –回车换行

–:

–CRLF

–CRLF

–CRLF

–CRLF

–“URL” 是所请求的资源的 URL 。

Page 80: TCP/IP 应用层协议

HTTP 的报文结构(请求报文)

–方 法 –URL –版 本–首部字段名

–首部行–: –值

–首部字段名 –值

–:

– …

–实体主体–(通常不用)

–请求行

–空格 –回车换行

–:

–CRLF

–CRLF

–CRLF

–CRLF

–“版本”是 HTTP 的版本。

Page 81: TCP/IP 应用层协议

HTTP 的报文结构(响应报文)

–版 本 –状态码 –短 语–首部字段名

–首部行–: –值

–首部字段名 –值

–:

– …

–实体主体–(有些响应报文不用)

–状态行

–空格 –回车换行

–:

–CRLF

–CRLF

–CRLF

–CRLF

–响应报文的开始行是状态行。–状态行包括三项内容,即 HTTP 的版本,状态码,以及解释状态码的简单短语。

–开始行

Page 82: TCP/IP 应用层协议

状态码都是三位数字 • 1xx 表示通知信息的,如请求收到了或正在进

行处理。• 2xx 表示成功,如接受或知道了。• 3xx 表示重定向,表示要完成请求还必须采取

进一步的行动。• 4xx 表示客户的差错,如请求中有错误的语法

或不能完成。• 5xx 表示服务器的差错,如服务器失效无法完

成请求。

Page 83: TCP/IP 应用层协议

http 报文格式 : request• 两种类型的 http messages: request, response• http request message:

– ASCII ( 人能够阅读的格式 )

–GET /somedir/page.html HTTP/1.0 –User-agent: Mozilla/4.0 –Accept: text/html, image/gif,image/jpeg–Accept-language:fr

–(extra carriage return, line feed)

–request line–(GET, POST,

–HEAD commands)

–header– lines

–Carriage return, –line feed

–indicates end –of message

Page 84: TCP/IP 应用层协议

http 报文格式 : response

–HTTP/1.0 200 OK –Date: Thu, 06 Aug 1998 12:00:15 GMT –Server: Apache/1.3.0 (Unix) –Last-Modified: Mon, 22 Jun 1998 ... –Content-Length: 6821 –Content-Type: text/html– –data data data data data ...

–status line–(protocol

–status code–status phrase)

–header– lines

–data, e.g., –requested–html file

Page 85: TCP/IP 应用层协议

http 响应状态码

200 OK– request succeeded, requested object later in this

message301 Moved Permanently

– requested object moved, new location specified later in this message (Location:)

400 Bad Request– request message not understood by server

404 Not Found– requested document not found on this server

505 HTTP Version Not Supported

– In first line in server->client response message.– A few sample codes:

Page 86: TCP/IP 应用层协议

Conditional GET :客户端缓存

• 目标:如果客户端有未修改的对象则不必重新发送该对象,节约带宽,提高响应速度。

• Client :在 http request 中说明缓存中该数据对象的日期:If-modified-since: <date>

• Server :如果该数据对象没有被修改,返回的响应中不包含该对象:HTTP/1.0 304 Not Modified

–client –server

–http request msg–If-modified-since:

<date>

–http response–HTTP/1.0

–304 Not Modified

–object –not

–modified

–http request msg–If-modified-since:

<date>

–http response–HTTP/1.1 200 OK

–<data>

–object –modified

Page 87: TCP/IP 应用层协议

浏览器的功能

• 接收 URL 输入(超链点击)并发送请求报文

• 显示并解释接收到的响应报文• 导航功能• 服务功能• 接受用户对浏览器的设置

Page 88: TCP/IP 应用层协议

浏览器的功能

• 统一资源定位器( Uniform Resource Locator , URL )也称 Web 地址。是在Web 页面中定义信息资源位置的标准方法。– 例如: http://www.zjut.edu.cn/index.htm

• URL 的构成:– < 协议 > < 主机 [端口号 ]> < 路径> < 文件名 >– 通过 URL可以访问因特网上的多种资源。

Page 89: TCP/IP 应用层协议

浏览器的功能

• 浏览器可以用的协议(方法)包括:– http:// (超文本传输协议)– ftp:// (文件传输协议)– gopher:// (菜单式检索)– telnet:// (远程仿真终端协议)– news:< 新闻组 > (新闻组访问)– mailto:< 邮件地址 > (邮件访问)

Page 90: TCP/IP 应用层协议

浏览器的功能• 浏览器屏幕可显示的内容包括:

– 网页正文– 超链信息,导航按钮(引导到其他网页)– 图像信息(一般为 jpg 格式的压缩图像)– 音频 /视频信息(音乐、电影)– 动态信息(动态的广告信息)– 进行交互功能的表单(如电子邮件用户的注册表格)

Page 91: TCP/IP 应用层协议

浏览器的功能

• 导航功能– 向前,向后(翻到曾经显示的前 / 后一个网页)– 打开,搜索(将文件系统中存储的网页文件打

开)– 历史资料(根据时间检索曾经访问的网页)– 插入书签(将重要的网页访问连接存入系统)

Page 92: TCP/IP 应用层协议

浏览器的功能• 服务功能

– 打印(将网页从打印机输出)– 邮件发送(将网页作为邮件发送)– 存成文件(将网页和所携信息分别存储)– 查看网页代码(查看代码,学习网页设计)– 帮助信息 (理解浏览器的应用 )– 刷新(请求最新的网页内容)– 停止(中断网页的下载过程)

Page 93: TCP/IP 应用层协议

HTML 语言• HTML :超文本标记语言( Hypertext Markup

Language )– 加入了许多被称为链接标签 (tag) 的特殊字符串的普通文本文件。

• 从结构上讲, HTML文件由许多种元素 (element) 组成,这些元素用于组织文件的内容和指导文件的输出格式。绝大多数元素是“容器”,即它有起始标记和结尾标记。

• 元素的起始标记叫做起始链接标签 (start tag) ,元素结束标记叫做结尾链接标签 (end tag) ,在起始链接标签和结尾链接标签中间的部分是元素体。

Page 94: TCP/IP 应用层协议

为什么要学习 HTML ?• HTML 是一种语言,但不是“程序设计”语言,

HTML 的作用是说明如何表现文字、图片,以及如何建立文件之间的连接。

• HTML 是各种网页新技术 (DHTML、 ASP、 PHP、JAVA Script) 的基础。

• 由于 HTML 不是程序语言,由其构成的文件不会因时、因地发生变化,也称为“静态网页”。

• 为了网页能够动态变化,需要在网页中加入程序,使之成为“动态网页”。

Page 95: TCP/IP 应用层协议

HTML 基本概念• 标记: <HTML>• 容器: <H1> Test</H1>• 标记的属性

– <IMG SRC=“stone.jpg” Height=200 Width=300>

–标记名称

–属性

Page 96: TCP/IP 应用层协议

HTML框架<HTML> <HEAD> Header element </HEAD> <BODY> body of Document </BODY></HTML>

Page 97: TCP/IP 应用层协议

HTML 框架<HTML>

<HEAD><TITLE> 我的网站</TITLE>

</HEAD><BODY BGCOLOR=lavender FONT=Arial>

<H1><FONT SIZE=3 ><B><I>仅仅是测试,不要见笑哟</I></B></FONT></H1></P>

</BODY></HTML>

Page 98: TCP/IP 应用层协议

扩充了功能的万维网服务器 –万维网服务器

–浏览器– 程序

–万维网客户

–服务器– 程序–HTTP

–数据库

–CGI

–HTTP 请求报文– ① 请求文档

– ② CGI 程序创建–动态文档

– ③ 响应动态文档–HTTP 响应报文

Page 99: TCP/IP 应用层协议

通用网关接口 CGI(Common Gateway

Interface) • CGI 是一种标准,它定义了动态文档应如何创建,输入数据应如何提供给应用程序,以及输出结果应如何使用。

• 万维网服务器与 CG I 的通信遵循 CGI 标准。• “ 通用”: CGI 标准所定义的规则对其他任

何语言都是通用的。• “ 网关”: CGI 程序的作用像网关。• “ 接口”:有一些已定义好的变量和调用等可

供其他 CGI 程序使用。

Page 100: TCP/IP 应用层协议

CGI 程序

• CGI 程序的正式名字是 CGI 脚本(script) 。

• “脚本”指的是一个程序,它被另一个程序(解释程序)而不是计算机的处理机来解释或执行。

•脚本运行起来要比一般的编译程序要慢,因为它的每一条指令先要被另一个程序来处理(这就要一些附加的指令),而不是直接被指令处理器来处理。

Page 101: TCP/IP 应用层协议

小 结 • ICMP 协议• TCP 协议• UDP 协议• 域名及其解析( DNS )• Telnet、 Email、 FTP 协议•万维网( HTTP )•预习: HTML语言和网页设计