【1.8.1.1】ftp

文件传输协议(File Transfer Protocol,FTP)是一种提供网络之间共享文件的协议,它可以在计算机之间可靠、高效地传送文件。在传输时,传输双方的操作系统、磁盘文件系统类型可以不同。

一、ftp 简介

FTP 协议允许 TCP/IP 网络上的两台计算机之间进行文件传输。而 FTP 服务是基于 FTP 协议的文件传输服务。

工作时,一台计算机上运行 FTP 客户端应用程序,另一台计算机上需要运行 FTP 服务器端程序。只有拥有了 FTP 服务,客户端才能进行文件传输。下面介绍FTP服务的构成和文件传输模式。

1.1 FTP 服务构成

上述的文件传输,指的是客户端和FTP服务器端之间的文件传输,如文件上传和下载。要实现文件传输还需要满足两个条件,如下:

  • 服务器端必须开启一个 TCP 端口(默认为 21 端口),用来监听来自客户端的请求。
  • 客户端连接 FTP 服务器端,需要使用 TCP 方式。这样可以保证客户端和服务器之间的会话是可靠的。

客户端与FTP服务器端之间传输一个文件是一次完整的 FTP 会话。该会话包含有两个连接,分别为控制连接和数据连接。其作用如下:

  • 控制连接:客户端向 FTP 服务器的 21 端口发送连接,服务器接受连接,建立一条命令通道。FTP 的命令和应答就是通过控制连接来传输的,这个连接会存在于整个 FTP 会话过程中。该连接主要负责将命令从客户端传给服务器,并将服务器的应答返回给客户端。所以,该连接不用于发送数据,只用于传输命令。
  • 数据连接:每当一个文件在客户端与服务器之间进行传输时,就会创建数据连接。该连接主要用来进行文件传输。

1.2 数据格式

在使用 FTP 进行文件传输时,针对不同的文件类型,FTP 提供了两种文件传输模式,分别为 ASCII 和二进制。这两种模式支持的文件如下:

  • ASCII:用于传输简单的文本文件,为默认类型。
  • 二进制:用于传输程序文件、字处理文档、可执行文件或图片。

二、FTP的基本使用(非常详细)

有了 FTP 服务器以后,客户端就可以与其建立连接,进行登录,然后进行文件传输,并实现各种操作,如上传文件/目录、下载文件/目录、列出目录信息等操作。

下面介绍 FTP 操作的基本使用。

2.1 构建 FTP 服务器

使用 FTP 服务,首先需要构建一个 FTP 服务器。为了便于测试,这里使用 netwox 工具中编号为 168 的模块,它可以在主机上构建一个 FTP 服务器。

其语法格式如下:

netwox 168 -l login -L password

参数说明:

-l 选项用来指定 FTP 服务器登录的用户名。
-L 选项用来指定 FTP 服务器登录的密码。

2.2 下载文件及校验

为了检查文件在传输过程中是否有损坏,需要对文件进行校验。一般情况下,会在文件传输之前计算它的哈希值,传输后再次计算它的哈希值。如果两次的哈希值一样,则表示文件没有损坏。

netwox 工具提供编号为 174 的模块,它可以从 FTP 服务器端下载文件,并检查它的 MD5 哈希值。

其语法格式如下:

netwox 174 -i IP -F file -m MD5 -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-F 选项指定要下载的文件名称。
-m 选项指定文件预期的 MD5 哈希值。
-u 选项指定 FTP 服务器登录的用户名。
-a 选项指定登录的密码。

【实例】已知 FTP 服务器的 IP 地址为 192.168.59.135,登录用户名为 sm,密码为 123。在该服务器上有一个 file.txt 文件。使用 netwox 工具,下载该文件,并校验其哈希值。

  1. 假设文件的哈希值为 c23f95941f9e226044a622c925b5fd2b,执行命令如下:

    root@daxueba:~# netwox 174 -i 192.168.59.135 -F file.txt 4566.txt –m c23f95941f9e226044a622c925b5fd2b -u sm -a 123

执行命令后,没有输出任何信息,表示下载文件 file.txt 的哈希值和指定值是一致的。

  1. 如果提供一个错误的哈希值 12345678901234567890123456789012,执行命令如下:

    root@daxueba:~# netwox 174 -i 192.168.59.135 -F file.txt -m 12345678901234567890123456789012 -u sm -a 123

输出信息如下:

MD5 is c23f95941f9e226044a622c925b5fd2b instead of 12345678901234567890123456789012

以上输出信息表示,file.txt 文件的 MD5 哈希值不是 12345678901234567890123456789012,而是 c23f95941f9e226044a622c925b5fd2b。

2.3 列出 FTP 服务器上目录列表信息

成功登录 FTP 服务器以后,用户就可以查看服务器上的目录信息了。netwox 工具提供了一个编号为 111 的模块,它可以列出当前目录下的所有信息,但不能列出子目录中的信息。

其语法格式如下:

netwox 111 -i IP --dir file.txt -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
--dir 选项指定要列出的目录名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】已知 FTP 服务器上有一个目录 content。使用 netwox 工具列出该目录中的信息,具体步骤如下:

  1. 在 FTP 服务器上,查看该目录的信息,执行命令如下:

    root@daxueba:~# ls content/

输出信息如下:

dir-1  dir-2  file.txt  pass-1.txt  pass-2.txt

以上输出信息表示该目录中包含了 3 个文件和 2 个目录。

  1. 使用 netwox 工具,在客户端列出该文件夹的目录信息,执行命令如下:

    root@daxueba:~# netwox 111 -i 192.168.59.135 –dir content -u sm -a 123

输出信息如下:

pass-1.txt (file of size 23)
file.txt (file of size 27)
pass-2.txt (file of size 18)
dir-2 (dir)
dir-1 (dir)

将以上输出信息与步骤(1)的输出信息对比可以看出,成功列出了该目录中的所有信息,包含的文件分别为 pass-1.txt,file.txt 和 pass-3.txt,并且给出了对应的大小。

2.4 下载文件

成功登录 FTP 服务器以后,用户就可以从服务器上下载文件了。netwox 工具提供了编号为 112 的模块,它可以从 FTP 服务器上下载指定文件。

其语法格式如下:

netwox 112 -i IP -F file1.txt -f file2.txt -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-F 选项指定 FTP 服务器上的文件名称,即要下载的文件。
-f 选项指定下载到本机后的文件名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】从 FTP 服务器上下载文件 file.txt,下载后的文件名称命名为 keep.txt。执行命令如下:

root@daxueba:~# netwox 112 -i 192.168.59.135 -F file.txt -f keep.txt -u sm -a 123

执行命令后没有任何输出信息,但是会成功下载文件 file.txt,下载后的文件名为 keep.txt。

2.5 上传文件

成功登录 FTP 服务器以后,用户还可以向服务器上传文件。netwox 工具提供了编号为 113 的模块,实现文件上传功能。

其语法格式如下:

netwox 113 -i IP -f file1.txt -F file2.txt -u login -a password

参数说明:

-i 选项指定 FTP 服务器的IP地址。
-f 选项指定要上传的文件名称,即本地文件。
-F 选项指定上传到 FTP 服务器后的文件名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】将本地文件 keep1.txt 上传到 FTP 服务器上,命名为 keep2.txt。执行命令如下:

root@daxueba:~# netwox 113 -i 192.168.59.135 -f keep1.txt -F keep2.txt –u sm -a 123

执行命令后没有任何输出信息,但是会将本地文件 keep1.txt 上传到 FTP 服务器上,文件名为 keep2.txt。

2.6 FTP 删除文件

登录 FTP 服务器后,用户还可以在客户端上删除 FTP 服务器上的文件。netwox 工具提供了编号为 114 的模块实现该功能。

其语法格式如下:

netwox 114 -i IP -F file -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-F 选项指定要删除 FTP 服务器上的文件名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】删除 FTP 服务器上的 file.txt 文件,执行命令如下:

root@daxueba:~# netwox 114 -i 192.168.59.135 -F file.txt -u sm -a 123

执行命令后没有任何输出信息,但是会将 FTP 服务器上的 file.txt 文件删除。

2.7 下载目录

netwox 工具中编号为 112 的模块可以下载指定的文件。如果要下载服务器上某个目录,需要使用编号为 114 的模块。该模块不仅可以下载目录,还可以列出目录及子目录信息。

其语法格式如下:

netwox 114 -i IP -F DIR1 -f DIR2 -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-F 选项指定 FTP 服务器的目录名称。
-f 选项用来指定下载的目录在本地显示的目录名称。
-u 选项用来指定 FTP 服务器登录的用户名。
-a 选项用来指定 FTP 服务器登录的密码。

【实例】已知 FTP 服务器上有一个目录 Dir,使用 netwox 工具下载该目录的所有内容。具体步骤如下:

  1. 查看目录 Dir 包含的信息,执行命令如下:

    root@daxueba:~# ls Dir -R

输出信息如下:

Dir:
dir-1  dir-2  dir-3  pass.txt

Dir/dir-1:
file-1.txt

Dir/dir-2:
file-2.txt

Dir/dir-3:
file-3.txt

以上输出信息表示目录Dir中包含了 3 个子目录,分别为 dir-1,dir-2 和 dir-3,还包含了一个文件 pass.txt。

在子目录 dir-1 中包含了一个文件 file-1.txt,在子目录 dir-2 中包含了一个文件 file-2.txt,在子目录 dir-3 中包含了一个文件 file-3.txt。

  1. 使用 netwox 工具从 FTP 服务器下载目录 Dir 中的所有目录信息,下载后目录名称为 DIR,执行命令如下:

    root@daxueba:~# netwox 115 -i 192.168.59.135 -F Dir -f DIR -u sm -a 123

输出信息如下:

DIR/dir-3
DIR/dir-3/file-3.txt
DIR/dir-2
DIR/dir-2/file-2.txt
DIR/pass.txt
DIR/dir-1
DIR/dir-1/file-1.txt

将以上输出信息与步骤(1)的输出信息进行对比,可以看出成功下载了所有的信息。

2.8 上传目录

登录 FTP 服务器以后,用户不仅可以从服务器下载整个目录,还可以将本地的目录上传到 FTP 服务器。netwox 工具提供了编号为 116 的模块,它可以进行递归上传,将本地目录以及子目录中的内容都上传到服务器。

其语法格式如下:

netwox 116 -i IP -f DIR1 -F DIR2 -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-f 选项指定要上传的本地目录名称。
-F 选项指定上传到 FTP 服务器的目录名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】将本地目录 DIR 上传到服务器,上传后的目录名称设置为 Mydir,执行命令如下:

root@daxueba:~# netwox 116 -i 192.168.59.135 -f DIR -F Mydir -u sm -a 123

输出信息如下:

DIR/dir-3
DIR/dir-3/file-3.txt
DIR/dir-2
DIR/dir-2/file-2.txt
DIR/pass.txt
DIR/dir-1
DIR/dir-1/file-1.txt

以上输出信息显示了上传目录的所有文件和子目录,可以看到上传了目录下的子目录 dir-1,dir-2,dir-3 和多个文件。

2.9 递归删除目录

如果 FTP 服务器上的某个目录不再需要,可以将其删除。netwox 工具中编号为 117 的模块提供了删除目录的功能。它可以递归删除目录中的所有信息,包括子目录及子目录下的所有内容。

其语法格式如下:

netwox 117 -i IP -F DIR -u login -a password

参数说明:

-i 选项指定 FTP 服务器的 IP 地址。
-F 选项指定要删除的 FTP 服务器上的目录名称。
-u 选项指定登录的用户名。
-a 选项指定登录的密码。

【实例】删除 FTP 服务器上的 Mydir 目录,执行命令如下:

root@daxueba:~# netwox 117 -i 192.168.59.135 -F Mydir -u sm -a 123

输出信息如下:

Entering directory Mydir
Entering directory dir-3
Deleting file file-3.txt
Leaving directory dir-3
Deleting directory dir-3
Entering directory dir-2
Deleting file file-2.txt
Leaving directory dir-2
Deleting directory dir-2
Deleting file pass.txt
Entering directory dir-1
Deleting file file-1.txt
Leaving directory dir-1
Deleting directory dir-1
Deleting directory Mydir

以上输出信息显示了递归删除目录内容的整个过程。

例如,首先进入目录 Mydir。由于该目录中包含子目录 dir-3,再进入子目录 dir-3 中;将该子目录中的文件 file-3.txt 进行删除,然后离开子目录 dir-3,删除该子目录。以此类推,删除指定目录中的所有信息。

参考资料

药企,独角兽,苏州。团队长期招人,感兴趣的都可以发邮件聊聊:tiehan@sina.cn
个人公众号,比较懒,很少更新,可以在上面提问题,如果回复不及时,可发邮件给我: tiehan@sina.cn