一.工作原理
FTP提供交互式的访问,允许客户指明文件的类型与格式,并允许文件具有存取权限;屏蔽了各计算机系统的细节,因而适合于在异构网络中的任意计算机之间传送文件;FTP采用客户/服务器(C/S)的工作方式,它使用TCP可靠的传输服务。
*注:FTP并不适合用在两个计算机之间共享读写文件
当一台主机从FTP服务器下载文件时,在该FTP服务器上对数据进行封装的转换步骤:数据、数据段、数据报、数据帧、比特
1.功能
(1)提供不同种类主机系统(硬、软件体系等都可以不同)之间的文件传输能力。因此可以在不同类型的操作系统之间传送文件
(2)以用户权限管理的方式提供用户对远程FTP服务器上的文件管理能力
(3)以匿名FTP的方式提供公用文件共享的能力
*注:针对文件传输FTP,系统管理员建立了一个特殊的用户ID,名为anonymous,即匿名用户。Internet上的任何人在任何地方都可以使用该用户ID,只是在要求提供用户ID时必须输入anonymous,该用户ID的密码可以是任何字符串。
2.FTP进程组成
主进程:负责接收新的请求
若干从属进程:处理单个请求
3.工作步骤
(1)打开熟知端口21(控制端口),使客户进程能够连接上
(2)等待客户进程发连接请求
(3)启动从属进程来处理客户进程发来的请求。主进程与从属进程并发执行,从属进程对客户进程的请求处理完毕后即终止
(4)回到等待状态,继续接收其他客户进程的请求
4.是否使用TCP20端口建立数据连接与传输模式有关
(1)主动方式使用TCP 20端口
*主动方式:客户进程向服务器进程发出连接建立请求,寻找21号端口,同时告知自己进程的端口号码用于建立数据连接。服务器端(主动)使用20号端口与客户刚刚提供的端口建立数据传送连接。然后即可传输文件。
*注:服务器进程用自己的20号端口 与 客户进程提供的端口 建立连接。因此20/21号端口是服务器的,客户不能用。
(2)被动方式由服务器和客户端自行协商决定(端口>1024)
*被动方式:客户进程向服务器进程发出连接建立请求,寻找21号端口,同时告知自己进程的端口号码用于建立数据连接。客户端给服务器端发出请求,询问服务器端口号,服务器收到后(被动)返回端口号(>1024),用于建立数据传送连接。然后即可传输文件。
二.控制连接与数据连接
1.特点:FTP在工作时使用两个并行的TCP连接。使用两个不同的端口号可使协议更加简单和更容易实现。FTP服务器必须在整个会话期间保留用户的状态信息。
2.控制连接(端口号21)
服务器监听21号端口,等待客户连接,建立在这个端口上的连接称为控制连接。控制连接用来传输控制信息(如连接请求、传送请求等FTP命令),并且控制信息都以7位ASCII格式传送
控制连接在整个会话期间一直保持打开状态
从图中可以看出
客户端包括:用户界面、控制进程、数据传送进程
服务器端包括:控制进程、数据传送进程
3.数据连接(端口号20)
服务器端的控制进程在接收到FTP客户发来的文件传输请求后,就创建数据传送进程和数据连接。传送完毕后关闭“数据传送连接"并结束运行。文件的列表是通过数据连接来传输的。
*注:由于FTP传输控制信息 使用的是 数据连接外的控制连接,因此FTP的控制信息是带外传送的。
三.FTP传输模式
1.文本模式:ASCII模式,以文本序列传输数据
2.二进制模式:Binary模式,以二进制序列传输数据