⽂件传输协议FTPTFTPSSHSCP——应⽤层
常见的⽂件传输协议:FTP、TFTP、SSH、SCP
⼀、FTP(英⽂:File Transfer Protocol,缩写:FTP)
1、概念
FTP是在⽹络层传输⽂件的应⽤层协议,基于TCP连接,使⽤客户/服务器模式。
对于ftp服务器来说,常⽤的端⼝有两个,⼀个是tcp端⼝21,此端⼝经常⽤于连接,另⼀个是tcp端⼝号20, 此端⼝经常⽤于传输数据。
2、FTP⽀持两种模式:
1. Standard (PORT⽅式,主动⽅式),
客户端与服务器的 21端⼝建⽴连接,⽤来发送命令,客户端获取数据时通过端⼝21发送PORT命令。PORT命令包含了客户端接收数据的端⼝号。传送数据时,服务器端通过TCP 20端⼝连接⾄客户端的指定端⼝发送数据。FTP server必须和客户端建⽴⼀个新的连接⽤来传送数据。cipher命令
2. Passive (PASV,被动⽅式)。
建⽴控制通道和Port模式类似,但建⽴连接后发送Pasv命令。服务器收到Pasv命令后,打开⼀个临时端⼝(端⼝号⼤于1023⼩于65535)并且通知客户端在这个端⼝上传送数据的请求,客户端连接FTP服务器此端⼝,然后FTP服务器将通过这个端⼝传送数据。
缺点:FTP有着极⾼的延时,这意味着,从开始请求到第⼀次接收需求数据之间的时间,会⾮常长;并且不时的必须执⾏⼀些冗长的登录进程。
3、命令参数
ftp> ascii # 设定以ASCII⽅式传送⽂件(缺省值)
ftp> bell # 每完成⼀次⽂件传送,报警提⽰.
ftp> binary # 设定以⼆进制⽅式传送⽂件.
ftp> bye # 终⽌主机FTP进程,并退出FTP管理⽅式.
ftp> case # 当为ON时,⽤MGET命令拷贝的⽂件名到本地机器中,全部转换为⼩写字母.
ftp> cd # 同UNIX的CD命令.
ftp> cdup # 返回上⼀级⽬录.
ftp> chmod # 改变远端主机的⽂件权限.
ftp> close # 终⽌远端的FTP进程,返回到FTP命令状态, 所有的宏定义都被删除.
ftp> delete # 删除远端主机中的⽂件.
ftp> dir [remote-directory] [local-file] # 列出当前远端主机⽬录中的⽂件.如果有本地⽂件,就将结果写⾄本地⽂件.
ftp> get [remote-file] [local-file] # 从远端主机中传送⾄本地主机中.
ftp> help [command] # 输出命令的解释.
ftp> lcd # 改变当前本地主机的⼯作⽬录,如果缺省,就转到当前⽤户的HOME⽬录.
ftp> ls [remote-directory] [local-file] # 同DIR.
ftp> macdef # 定义宏命令.
ftp> mdelete [remote-files] # 删除⼀批⽂件.
ftp> mget [remote-files] # 从远端主机接收⼀批⽂件⾄本地主机.
ftp> mkdir directory-name # 在远端主机中建⽴⽬录.
ftp> mput local-files # 将本地主机中⼀批⽂件传送⾄远端主机.
ftp> open host [port] # 重新建⽴⼀个新的连接.
ftp> prompt # 交互提⽰模式.
ftp> put local-file [remote-file] # 将本地⼀个⽂件传送⾄远端主机中.
ftp> pwd # 列出当前远端主机⽬录.
ftp> quit # 同BYE.
ftp> recv remote-file [local-file] # 同GET.
ftp> rename [from] [to] # 改变远端主机中的⽂件名.
ftp> rmdir directory-name # 删除远端主机中的⽬录.
ftp> send local-file [remote-file] # 同PUT.
ftp> status # 显⽰当前FTP的状态.
ftp> system # 显⽰远端主机系统类型.
ftp> user user-name [password] [account] # 重新以别的⽤户名登录远端主机.
ftp> ? [command] # 同HELP. [command]指定需要帮助的命令名称。如果没有指定 command,ftp 将显⽰全部命令的列表。
ftp> ! # 从 ftp ⼦系统退出到外壳。
4、常⽤命令
下载: # 下载 ⽂件
上传: # 上传⽂件
⼆、TFTP (Trivial File Transfer Protocol,简单⽂件传输协议)
1、概念
TFTP是TCP/IP协议族中在客户机与服务器之间进⾏简单⽂件传输的协议,提供不复杂、开销不⼤的⽂件传输服务。端⼝号为69。
2、TFTP协议的优势
(1)TFTP能够⽤于那些有UDP⽽⽆TCP的环境;
(2)TFTP代码所占的内存要⽐FTP⼩。
3、TFTP协议与FTP协议的不同点
(1)TFTP协议不需要验证客户端的权限,FTP需要进⾏客户端验证;
(2)TFTP协议⼀般多⽤于局域⽹以及远程UNIX计算机中,⽽常见的FTP协议则多⽤于互联⽹中;
(3)FTP客户与服务器间的通信使⽤TCP,⽽TFTP客户与服务器间的通信使⽤的是UDP;
(4)TFTP只⽀持⽂件传输。也就是说,TFTP不⽀持交互,⽽且没有⼀个庞⼤的命令集。最为重要的是,TFTP不允许⽤户列出⽬录内容或者与服务器协商来决定哪些是可得到的⽂件。
4、命令参数
-l 是local的缩写,后跟存在于Client的源⽂件名,或下载Client后 重命名的⽂件名。
-r 是remote的缩写,后跟Server即PC机tftp服务器根⽬录中的源⽂ 件名,或上传Server后重命名后的⽂件名。
-g 是get的缩写,下载⽂件时⽤,
-p 是put的缩写,上传⽂件时⽤,
5、常⽤命令
下载东西: tftp -g - - 192.168.1.1
上传东西:tftp -p - - 192.168.1.1
三、SSH(Secure Shell)
1、概念
SSH协议是基于应⽤层的协议,为远程登录会话和其他⽹络服务提供安全性的协议。
传统协议(ftp、telnet等)等都是⾮安全的协议,其⼯作机制很容易泄露数据。⽽SSH在传输过程中的数据是加密的,安全性更⾼。
其实ssh协议的主要功能使⽤并⾮是在传输⽂件,⽽是远程登陆,因为ssh基于⾮对称加密⽅法的,服务器和客户端都会⽣成⾃⼰的公钥和私钥,私钥仅有⾃⼰能够获取,只需要给予对⽅公钥,⽽数据解密需要公钥和私钥同时配合,所以,该协议很⼤程度上保证了数据的安全性。
⾄于信息安全⽅⾯,我这⾥就不做介绍了,等有时间再整理⼀下,发布出来。
2、特点
ssh协议最⼤的特点就是安全,这⾥对ssh的介绍并不是介绍其传输⽂件的功能,⽽是以其安全性能⾼的特点来引申SCP协议。
四、SCP (Secure Copy协议)
1、概念
scp⽤于Linux之间复制⽂件和⽬录。基于ssh登陆进⾏安全的远程⽂件拷贝命令。SSH连接隧道是安全的,因⽽基于SCP协议的⽂件传输是安全的。
SCP协议分为SCP Client和SCP Server。⽆论是server端还是client端,都⽀持上传和下载的功能。
2、命令参数
-1:强制scp命令使⽤协议ssh1
-2:强制scp命令使⽤协议ssh2
-4:强制scp命令只使⽤IPv4寻址
-6:强制scp命令只使⽤IPv6寻址
-B:使⽤批处理模式(传输过程中不询问传输⼝令或短语)
-C:允许压缩。(将-C标志传递给ssh,从⽽打开压缩功能)
-p  保留原⽂件的修改时间,访问时间和访问权限。
-q:不显⽰传输进度条。
-r:递归复制整个⽬录。
-v:详细⽅式显⽰输出。scp和ssh(1)会显⽰出整个过程的调试信息。这些信息⽤于调试连接,验证和配置问题。
-c cipher:以cipher将数据传输进⾏加密,这个选项将直接传递给ssh。
-F ssh_config:指定⼀个替代的ssh配置⽂件,此参数直接传递给ssh。
-i identity_file:从指定⽂件中读取传输时使⽤的密钥⽂件,此参数直接传递给ssh。
-l limit:限定⽤户所能使⽤的带宽,以Kbit/s为单位。
-o ssh_option:如果习惯于使⽤ssh_config(5)中的参数传递⽅式,
-P port:注意是⼤写的P, port是指定数据传输⽤到的端⼝号
-S program:指定加密传输时所使⽤的程序。此程序必须能够理解ssh(1)的选项。
3、常⽤命令
命令格式: scp srcusername@srcip:srcpath/srcfile dstusername@dstip:dstpath/dstfile
其中可以根据上传和下载的⽅式省略掉其中⼀各参数,具体如下:
上传:scp -r local_dir username@servername:remote_dir
下载:scp username@servername:/path/filename /var/www/local_dir

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。