FTP是在两个计算机之间传输文件的协议。一般有两种情形,一种是需要登录的FTP文件服务器,另外一种FTP服务器是匿名的,它允许任何人进行访问。
FTP使用两条TCP连接:一条用来控制,另一条用来数据传输。
用于控制的TCP连接主要在FTP的控制部分使用。例如:登录用户名和密码的验证,发送文件的名称等。这个连接可以通过ASCII来发送请求和接受应答。(也就是通过命令的方式)该控制连接使用的默认端口是21。当发生GET,PUT以及文件浏览的时候,每次都会建立另外一个TCP连接(默认占用20端口)。这个TCP连接是用来传输数据的,当数据传输完毕的时候,这个TCP连接就会被断开。
当FTP请求成功的时候,服务器也会返回响应,也有和HTTP类似的状态码来标识访问操作的信息。
FTP支持两种模式:
大多数防火墙在设置的时候都是不允许接受外部发起的连接的,所以许多位于防火墙后或内网的FTP服务器不支持PASV模式,因为客户端无法穿过防火墙打开FTP服务器的端口;而许多内网的客户端不能用PORT模式登陆FTP服务器,因为从服务器的20端口无法和内网的客户端建立一个新的连接,造成无法工作。
无论是选择PORT模式还是PASV模式都是取决于客户端的。
FTP服务器传输数据的时候可以选择是ASCII码模式或者是二进制模式。ASCII模式会在传输的时候自动调整文件的内容以便于把文件解释成另外那台计算机存储文本文件的格式。
二进制模式中保存文件的位序,以便原始和拷贝的是逐位一一对应的。