㈠定义
FTP(File Transfer Protocol,文件传输协议) 是 一个用于简化IP网络上系统之间文件传送的协议,是TCP/IP 协议组中的协议之一。
㈡组成
⑴FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端。
⑵其中FTP服务器用来存储文件,用户可以使用FTP客户端通过FTP协议访问位于FTP服务器上的资源。
⑶在开发网站的时候,通常利用FTP协议把网页或程序传到Web服务器上。
⑷此外,由于FTP传输效率非常高,在网络上传输大的文件时,一般也采用该协议。
㈢工作原理
⑴FTP有两个过程一个是控制连接,一个是数据传输。
⑵FTP协议不像HTTP协议一样需要一个端口作为连接(默认时HTTP端口是80, FTP端口是21)。
⑶FTP协议需要两个端口,一个端口是作为控制连接端口,也就是FTP的21端口,用于发送指令给服务器以及等待服务器响应;
⑷另外一个端口用于数据传输端口,端口号为20 (仅用PORT模式),是用建立数据传输通道的,
⑸主要作用是从客户向服务器发送一一个文件, 从服务器向客户发送一个文件, 从服务器向客户发送文件或目录列表。
㈣工作方式
⑴FTP支持两种模式,一种方式叫做Standard (也就是 PORT方式,主动方式),一种是 Passive(也就是PASV,被动方式)。
⑵Standard模式 FTP的客户端发送 PORT 命令到FTP服务器。
⑶Passive模式FTP的客户端发送 PASV命令到 FTP Server。
㈤PORT(主动模式)工作原理
⑴FTP 客户端首先和FTP服务器的TCP 21端口建立连接,通过这个通道发送命令,客户端需要接收数据的时候在这个通道上发送PORT命令。
⑵PORT命令包含了客户端用什么端口接收数据。
⑶在传送数据的时候,服务器端通过自己的TCP 20端口连接至客户端的指定端口发送数据。
⑷FTP server必须和客户端建立一个新的连接用来传送数据。
㈥PASV(被动模式)工作原理
⑴在建立控制通道的时候和 Standard 模式类似,但建立连接后发送的不是 Port 命令,而是 Pasv 命令。
⑵FTP 服务器收到 Pasv 命令后,随机打开一个高端端口(端口号大于 1024)并且通知客户端在这个端口上传送数据的请求,
⑶客户端连接 FTP 服务器此端口,通过三次握手建立通道,然后 FTP 服务器将通过这个端口进行数据的传送。
⑴很多防火墙在设置的时候都是不允许接受外部发起的连接的,
⑵所以许多位于防火墙后或内网的 FTP 服务器不支持 PASV 模式,
⑶因为客户端无法穿过防火墙打开 FTP 服务器的高端端口;
⑷而许多内网的客户端不能用 PORT 模式登陆 FTP 服务器,
⑸因为从服务器的 TCP 20 无法和内部网络的客户端建立一个新的连接,造成无法工作。
㈦传输模式
⑴FTP的传输有两种方式:ASCII传输模式和二进制数据传输模式。
⑵FTP协议的任务是从一台计算机将文件传送到另一台计算机,它与这两台计算机所处的位置、联接的方式、甚至是是否使用相同的操作系统无关。
⑶假设两台计算机通过ftp协议对话,并且能访问Internet,你可以用ftp命令来传输文件。
⑷每种操作系统使用上有某一些细微差别,但是每种协议基本的命令结构是相同的。
㈧ASCII传输模式
⑴假定用户正在拷贝的文件包含的简单ASCII码文本,如果在远程机器上运行的是不同的操作系统,
⑵当文件传输时ftp通常会自动地调整文件的内容以便于把文件解释成另外那台计算机存储文本文件的格式。
⑶但是常常有这样的情况,用户正在传输的文件包含的不是文本文件,
⑷它们可能是程序,数据库,字处理文件或者压缩文件
(尽管字处理文件包含的大部分是文本,其中也包含有指示页尺寸,字库等信息的非打印字符)。
⑸在拷贝任何非文本文件之前,用binary 命令告诉ftp逐字拷贝,不要对这些文件进行处理
㈨二进制传输模式
⑴在二进制传输中,保存文件的位序,以便原始和拷贝的是逐位一一对应的。
⑵即使目的地机器上包含位序列的文件是没意义的。
⑶例如,macintosh以二进制方式传送可执行文件到Windows系统,在对方系统上,此文件不能执行。
⑷如果你在ASCII方式下传输二进制文件,即使不需要也仍会转译。
⑸这会使传输稍微变慢 ,也会损坏数据,使文件变得不能用。
⑹在大多数计算机上,ASCII方式一般假设每一字符的第一有效位无意义,
⑺因为ASCII字符组合不使用它。如果你传输二进制文件,所有的位都是重要的.
⑻如果你知道这两台机器是同样的,则二进制方式对文本文件和数据文件都是有效的。
㈩用户授权
⑴授权
要连上 FTP 服务器(即“登陆”),必须要有该 FTP 服务器授权的帐号,
也就是说你只有在有了一个用户标识和一个口令后才能登陆FTP服务器,享受FTP服务器提供的服务。
⑵地址格式
ftp://用户名:密码@FTP服务器IP或域名:FTP命令端口/路径/文件名
上面的参数除FTP服务器IP或域名为必要项外,其他都不是必须的。
如以下地址都是有效FTP地址:
ftp://foolish.6600.org
ftp://list:list@foolish.6600.org
ftp://list:list@foolish.6600.org:2003
ftp://list:list@foolish.6600.org:2003/soft/list.txt
⑶匿名
①互联网中有很大一部分 FTP 服务器被称为“匿名”(Anonymous)FTP 服务器。
这类服务器的目的是向公众提供文件拷贝服务,不要求用户事先在该服务器进行登记注册,也不用取得FTP服务器的授权。
②Anonymous(匿名文件传输)能够使用户与远程主机建立连接并以匿名身份从远程主机上拷贝文件,
而不必是该远程主机的注册用户。
③用户使用特殊的用户名“anonymous”登陆FTP服务,就可访问远程主机上公开的文件。
许多系统要求用户将Email地址作为口令,以便更好地对访问进行跟综。
④匿名FTP一直是Internet上获取信息资源的最主要方式,
在Internet成千上万的匿名FTP主机中存储着无以计数的文件,
这些文件包含了各种各样的信息,数据和软件。
人们只要知道特定信息资源的主机地址,就可以用匿名FTP登录获取所需的信息资料。
⑤虽然使用WWW环境已取代匿名FTP成为最主要的信息查询方式,
但是匿名FTP仍是 Internet上传输分发软件的一种基本方法。
如red hat 、autodesk等公司的匿名站点。
(十一)FTP的限制
⑴对于FTP服务器来讲,他必须在整个会话期间保持用户的状态(state)
⑵特别是,服务器必须把特定的用户账户与控制联系起来,
⑶用户在远程目录树上不断跳转时,服务器必须追踪到用户在远程树上的当前位置,
⑷换句话说,当客户端用户数量不断增多,FTP服务器所要维持的会话总数,也会迅速增长。
⑸这会大大限制FTP服务器的性能。
(十二)FTP中的命令与应答
⑴命令
①FTP协议的命令是认可读的,每个命令由4个大写的ASCII字符组成,有些还可带一些可选参数,命令后面跟回车符换行。
②以下是比较常见的命令:
⑵应答
①FTP客户端每个发出的命令都会对应一个FTP服务器发出的应答。应带是一个3为的数字,后跟一个可选信息。他与http响应报文的状态码和状态信息的结构相同。
②比较常见的几个应带可以参考如下:
注意:FTP-RFC959中文版:https://wenku.baidu.com/view/fd5c3611f18583d049645969.html
里面有非常详细的有关FTP协议的相关知识,可以阅读参考。
参考:https://baike.baidu.com/item/FTP%E5%8D%8F%E8%AE%AE/7651119?fr=aladdin
https://www.cnblogs.com/liyong-blackStone/p/10309749.html