1、文件传输协议文件传输协议(FTP:File Transfer Protocol)使得主机间可以共享文件。 FTP 使用 TCP 生成一个虚拟连接用于控制信息,然后再生成一个单独的 TCP 连接用于数据传输。控制连接使用类似 TELNET 协议在主机间交换命令和消息。文件传输协议是 TCP/IP 网络上两台计算机传送文件的协议,FTP 是在 TCP/IP 网络和 INTERNET 上最早使用的协议之一,它属于网络协议组的应用层。FTP 客户机可以给服务器发出命令来下载文件,上传文件,创建或改变服务器上的目录。中文名: 文件传输协议外文名: File Transfer Protocol简称: FT
2、P类别: 文件传送协议目录简介工作原理主要功能网页浏览器FTP 和网站FTP 用户授权FTP 服务器展开简介FTP 是 TCP/IP 网络上两台计算机传送文件的协议,FTP 是在 TCP/IP 网络和 INTERNET 上最早使用的协议之一。尽管 World Wide Web(WWW)已经替代了 FTP 的大多数功能, FTP 仍然是通过 Internet 把文件从客户机复制到服务器上的一种途径。FTP 客户机可以给服务器发出命令来下载文件,上载文件,创建或改变服务器上的目录。原来的 FTP 软件多是命令行操作,有了像 CUTEFTP 这样的图形界面软件,使用 FTP 传输变得方便易学。主要使
3、用它进行 “上载”。即向服务器传输文件。由于 FTP 协议的传输速度比较快,我们在制作诸如“软件下载”这类网站时喜欢用 FTP 来实现,同时我们这种服务面向大众,不需要身份认证,即“匿名 FTP 服务器”。 1FTP 是应用层的协议,它基于传输层,为用户服务,它们负责进行文件的传输。 FTP 是一个 8 位的客户端-服务器协议,能操作任何类型的文件而不需要进一步处理,就像 MIME 或 Unicode 一样。但是,FTP 有着极高的延时,这意味着,从开始请求到第一次接收需求数据之间的时间会非常长,并且不时的必需执行一些冗长的登陆进程。FTP 服务一般运行在 20 和 21 两个端口。端口 20
4、 用于在客户端和服务器之间传输数据流,而端口 21 用于传输控制流,并且是命令通向 ftp 服务器的进口。当数据通过 数据流 传输时,控制流处于空闲状态。而当控制流 空闲很长时间后,客户端的防火墙会将其会话置为超时,这样当大量数据通过防火墙时,会产生一些问题。此时,虽然文件可以成功的传输,但因为控制会话会被防火墙断开,传输会产生一些错误。FTP(federal test procedure)是美国联邦实验程序,是一种实验标准工况。在从工况下进行轻型车和重型车的油耗、排放的实验测量,并进行对比。 1本标准中规定了随时间变化时发动机应该保持的转速,并测量这段时间内的油耗和排放情况等参数变化。 2工
5、作原理文件传输协议(FTP)是 TCP/IP 提供的标准机制。用来将文件从一个主机复制到另一个主机。FTP 使用 TCP 的服务。主要功能提供文件的共享(计算机程序 / 数据); 支持间接使用远程计算机; 使用户不因各类主机文件存储器系统的差异而受影响; 可靠且有效的传输数据。FTP ,尽管可以直接被终端用户使用,但其应用主要还是通过程序实现。FTP 控制帧即指 TELNET 交换信息,包含 TELNET 命令和选项。然而,大多数 FTP 控制帧是简单的 ASCII 文本,可以分为 FTP 命令或 FTP 消息。 FTP 消息是对 FTP 命令的响应,它由带有解释文本的应答代码构成。 2网页浏
6、览器大多数最新的网页浏览器和文件管理器都能和 FTP 服务器建立连接。这使得在 FTP 上通过一个接口就可以操控远程文件,如同操控本地文件一样。这个功能通过给定一个 FTP 的 URL 实现,形如 ftp:/。是否提供密码是可选择的,如果有密码,则形如ftp:/:。大部分网页浏览器要求使用被动 FTP 模式,然而并不是所有的 FTP 服务器都支持被动模式。网络协议应用层 DNS,FTP,ENRP,HTTP,IMAP,IIRC, NNTP,POP3,SIP,SMTP,SNMP,SSH,Telnet,BitTorrent,DHCP.传输层 DCCP,SCTP,TCP,RTP,UDP,IL,RUDP
7、, .网络层 IPv4,IPv6.数据链路层以太网,Wi-Fi,令牌环,MPLS ,PPP.物理层 RS-232,EIA-422,RS-449,EIA-485,10BASE2,10BASE-T.FTP 和网站我们都知道,当我们需要往网站空间上放网站文件的时候,我们可以采用 WEB 和 FTP 两种方法。在这里,我们建议直接使用FTP 进行 数据交换,因为不管是安全性还是快捷性来说, ftp 都是很不错的。那么我们怎么往空间上传送网站的数据文件呢,这时,我们就需要一个软件 FlashFXP 或者其他 FTP 客户端。这里我们以FlashFXP 为例,我们去网上下载这个软件包并解压出来,双击 Fl
8、ashFXP.exe 这个文件,进入页面之后,有一个闪电符号的按钮,这是连接。单击或者直接按 F8,这时会出来一个对话框,我们只需要输入网站的 URL 或者 IP,然后再输入用户名和密码就行,这时,我们就可以进行网站数据文件的传输了。FTP 用户授权(1)用户授权要连上 FTP 服务器(即“登陆”),必须要有该 FTP 服务器授权的帐号,也就是说你只有在有了一个用户标识和一个口令后才能登陆 FTP 服务器,享受 FTP 服务器提供的服务。(2)FTP 地址格式FTP 地址如下: ftp:/用户名:密码FTP 服务器 IP 或域名:FTP 命令端口/路径/ 文件名上面的参数除 FTP 服务器 I
9、P 或域名为必要项外,其他都不是必须的。FTP 服务器FTP 的全称是 File Transfer Protocol(文件传输协议),顾名思义,就是专门用来传输文件的协议。FTP 的主要作用,就是让用户连接上一个远程计算机(这些计算机上运行着 FTP 服务器程序)察看远程计算机有哪些文件,然后把文件从远程计算机上拷到本地计算机,或把本地计算机的文件送到远程计算机去。其实 早期在 Internet 上传输文件,并不是一件容易的事,我们知道 Internet 是一个非常复杂的计算机环境,有 PC、工作站、MAC、服务器、大型机等等,而这些计算机可能运行不同的操作系统,有 Unix、Dos 、 Wi
10、ndows、MacOS 等等,各种操作系统之间的文件交流,需要建立一个统一的文件传输协议,这就是所谓的 FTP。虽然基于不同的操作系统有不同的 FTP 应用程序,而所有这些应用程序都遵守同一种协议,这样用户就可以把自己的文件传送给别人,或者从其它的用户环境中获得文件。与大 多数 Internet 服务一样,FTP 也是一个客户机/服务器系统(C/S)。用户通过一个支持 FTP 协议的客户机程序,连接到远程主机上的 FTP 服务器 程序。用户通过客户机程序向服务器程序发出命令,服务器程序执行用户所发出的命令,并将执行的结果返回到客户机。比如说,用户发出一条命令,要求服务器向用户传送某一个文件,服
11、务器会响应这条命令,将指定文件送至用户的机器上。客户机程序代表用户接收到这个文件,将其存放在用户指定目录中。FTP 客户程序 有字符界面和图形界面两种。字符界面的 FTP 的命令复杂、繁多。图形界面的 FTP 客户程序,操作上要简洁方便的多。在 FTP 的使用当 中,用户经常遇到两个概念: “下载“(Download)和“上载“(Upload)。“下载“ 文件就是从远程主机拷贝文件至自己的计算机上;“上载“文 件就是将文件从自己的计算机中拷贝至远程主机上。用 Internet 语言来说,用户可通过客户机程序向(从)远程主机上载(下载 )文件。在 ftp 的使用过程中,必须首先登录,在远程主机上
12、获得相应的权限以后,方可上传或下载文件。也就是说,要想同哪一台计算机传送文件,就必须具有哪一台计算机的适当授权。换言之,除非有用户 ID 和口令,否则便无法传送文件。这种情况违背了 Internet 的开放性,Internet 上的 FTP 主机何止千 万,不可能要求每个用户在每一台主机上都拥有帐号。因此就衍生出了匿名 FTP。 3优缺点优点:1.促进文件的共享(计算机程序或数据)2.鼓励间接或者隐式的使用远程计算机3.向用户屏蔽不同主机中各种文件存储系统的细节4.可靠和高效的传输数据缺点:1.密码和文件内容都使用明文传输,可能产生不希望发生的窃听。2.因为必须开放一个随机的端口以建立连接,当
13、防火墙存在时,客户端很难过滤处于主动模式下的 FTP 流量。这个问题通过使用被动模式的 FTP 得到了很大解决。3.服务器可能会被告知连接一个第三方计算机的保留端口。FTP 虽然可以被终端用户直接使用,但是它是设计成被 FTP 客户端程序所控制。运行 FTP 服务的许多站点都开放匿名服务,在这种设置下,用户不需要 帐号就可以登录服务器,默认情况下,匿名用户的用户名是:“anonymous”。这个帐号不需要 密码,虽然通常要求输入用户的邮件地址作为认证密码,但这只是一些细节或者此邮件地址根本不被确定,而是依赖于 FTP 服务器的配置情况。使用模式FTP 有两种使用模式:主动和被动。主动模式要求客
14、户端和服务器端同时打开并且监听一个端口以建立连接。在这种情况下,客户端由于安装了防火墙会产生一些问题。所以,创立了被动模式。被动模式只要求服务器端产生一个监听相应端口的进程,这样就可以绕过客户端安装了防火墙的问题。 4一个主动模式的 FTP 连接建立要遵循以下步骤:1.客户端打开一个随机的端口(端口号大于 1024,在这里,我们称它为 x),同时一个 FTP 进程连接至服务器的 21 号命令端口。此时,源端口为随机端口 x,在客户端,远程端口为 21,在服务器。2.客户端开始监听端口(x+1),同时向服务器发送一个端口命令(通过服务器的 21 号命令端口),此命令告诉服务器客户端正在监听的端口
15、号并且已准备好从此端口接收数据。这个端口就是我们所知的数据端口。3.服务器打开 20 号源端口并且建立和客户端数据端口的连接。此时,源端口为 20,远程数据端口为(x+1)。4.客户端通过本地的数据端口建立一个和服务器 20 号端口的连接,然后向服务器发送一个应答,告诉服务器它已经建立好了一个连接。被动模式 FTP:为了解决服务器发起到客户的连接的问题,人们开发了一种不同的 FTP 连接方式。这就是所谓的被动方式,或者叫做 PASV,当客户端通知服务器它处于被动模式时才启用。在被动方式 FTP 中,命令连接和数据连接 都由客户端发起,这样就可以解决从服务器到客户端的数据端口的入方向连接被防火墙
16、过滤掉的问题。当开启一个 FTP 连接时,客户端打开两个任意的非特权本地端口( N 1024 和 N+1)。第一个端口连接服务器的 21 端口,但与主动方式的 FTP 不同,客户端不会提交 PORT 命令并允许服务器来回连它的数据端口,而是提交 PASV 命令。这样做的结果是服务器会开启一个任意的非特权端口(P 1024),并发送 PORT P 命令给客户端。然后客户端发起从本地端口 N+1 到服务器的端口 P 的连接用来传送数据。对于服务器端的防火墙来说,必须允许下面的通讯才能支持被动方式的 FTP:1. 从任何大于 1024 的端口到服务器的 21 端口 (客户端的初始化连接)2.服务器的
17、 21 端口到任何大于 1024 的端口 (服务器响应到客户端的控制端口的连接)3. 从任何大于 1024 端口到服务器的大于 1024 端口 (客户端初始化数据连接到服务器指定的任意端口)4.服务器的大于 1024 端口到远程的大于 1024 的端口(服务器发送 ACK 响应和数据到客户端的数据端口)协议结构命令 描述ABOR 中断数据连接程序ACCT 系统特权帐号ALLO 为服务器上的文件存储器分配字节APPE 添加文件到服务器同名文件CDUP 改变服务器上的父目录CWD 改变服务器上的工作目录DELE 删除服务器上的指定文件HELP 返回指定命令信息LIST 如果是文件名列出文件信息,如
18、果是目录则列出文件列表MODE 传输模式(S=流模式,B=块模式,C=压缩模式)MKD 在服务器上建立指定目录NLST 列出指定目录内容NOOP 无动作,除了来自服务器上的承认PASS 系统登录密码PASV 请求服务器等待数据连接PORT IP 地址和两字节的端口 IDPWD 显示当前工作目录QUIT 从 FTP 服务器上退出登录REIN 重新初始化登录状态连接REST 由特定偏移量重启文件传递RETR 从服务器上找回(复制)文件RMD 在服务器上删除指定目录RNFR 对旧路径重命名RNTO 对新路径重命名SITE 由服务器提供的站点特殊参数SMNT 挂载指定文件结构STAT 在当前程序或目录
19、上返回信息STOR 储存(复制)文件到服务器上STOU 储存文件到服务器名称上STRU 数据结构(F=文件,R=记录,P=页面)SYST 返回服务器使用的操作系统TYPE 数据类型(A=ASCII,E=EBCDIC,I=binary)USER 系统登录的用户名标准 FTP 信息如下响应代码 解释说明110 新文件指示器上的重启标记120 服务器准备就绪的时间(分钟数)125 打开数据连接,开始传输150 打开连接200 成功202 命令没有执行211 系统状态回复212 目录状态回复213 文件状态回复214 帮助信息回复215 系统类型回复220 服务就绪221 退出网络225 打开数据连接226 结束数据连接227 进入被动模式(IP 地址、ID 端口)230 登录因特网250 文件行为完成257 路径名建立331 要求密码332 要求帐号350 文件行为暂停421 服务关闭425 无法打开数据连接426 结束连接450 文件不可用451 遇到本地错误452 磁盘空间不足500 无效命令501 错误参数502 命令没有执行503 错误指令序列504 无效命令参数530 未登录网络532 存储文件需要帐号550 文件不可用551 不知道的页类型552 超过存储分配553 文件名不允许