我的编程空间,编程开发者的网络收藏夹
学习永远不晚

FTP的主动和被动模式是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

FTP的主动和被动模式是什么

这篇文章主要介绍“FTP的主动和被动模式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“FTP的主动和被动模式是什么”文章能帮助大家解决问题。

FTP(File Transfer Protocol)是文件传输协议的简称。正如其名所示:FTP的主要作用,就是让用户连接上一个远程计算机(这些计算机上运行着FTP服务器程序)察看远程计算机有哪些文件,然后把文件从远程计算机上拷到本地计算机,或把本地计算机的文件送到远程计算机去。

FTP支持两种方式的传输:文本(ASCII)方式和二进制(Binary)方式。通常文本文件的传输采用ASCII方式,而图象、声音文件、加密和压缩文件等非文本文件采用二进制方式传输,如果为了从一个系统上传输文件而使用了与本地系统不同的计算机字节位数,那么就必须使用Tenex模式。FTP以ASCII方式作为缺省的文件传输方式。

FTP的主动和被动模式是什么

主动模式FTP

主动模式下,FTP客户端从任意的非特殊的端口(N > 1023)连入到FTP服务器的命令端口–21端口。然后客户端在N+1(N+1 >= 1024)端口监听,并且通过N+1(N+1 >= 1024)端口发送命令给FTP服务器。服务器会反过来连接用户本地指定的数据端口,比如20端口。

以服务器端防火墙为立足点,要支持主动模式FTP需要打开如下交互中使用到的端口:

FTP服务器命令(21)端口接受客户端任意端口(客户端初始连接)FTP服务器命令(21)端口到客户端端口(>1023)(服务器响应客户端命令)FTP服务器数据(20)端口到客户端端口(>1023)(服务器初始化数据连接到客户端数据端口)FTP服务器数据(20)端口接受客户端端口(>1023)(客户端发送ACK包到服务器的数据端口)

用图表示如下:

  FTP的主动和被动模式是什么

在第1步中,客户端的命令端口与FTP服务器的命令端口建立连接,并发送命令“PORT 1027”。然后在第2步中,FTP服务器给客户端的命令端口返回一个”ACK”。在第3步中,FTP服务器发起一个从它自己的数据端口(20)到客户端先前指定的数据端口(1027)的连接,最后客户端在第4步中给服务器端返回一个”ACK”。

主动方式FTP的主要问题实际上在于客户端。FTP的客户端并没有实际建立一个到服务器数据端口的连接,它只是简单的告诉服务器自己监听的端口号,服务器再回来连接客户端这个指定的端口。对于客户端的防火墙来说,这是从外部系统建立到内部客户端的连接,这是通常会被阻塞的。

被动模式FTP

为了解决服务器发起到客户的连接的问题,人们开发了一种不同的FTP连接方式。这就是所谓的被动方式,或者叫做PASV,当客户端通知服务器它处于被动模式时才启用。

在被动方式FTP中,命令连接和数据连接都由客户端,这样就可以解决从服务器到客户端的数据端口的入方向连接被防火墙过滤掉的问题。当开启一个FTP连接时,客户端打开两个任意的非特权本地端口(N >; 1024和N+1)。第一个端口连接服务器的21端口,但与主动方式的FTP不同,客户端不会提交PORT命令并允许服务器来回连它的数据端口,而是提交PASV命令。这样做的结果是服务器会开启一个任意的非特权端口(P >; 1024),并发送PORT P命令给客户端。然后客户端发起从本地端口N+1到服务器的端口P的连接用来传送数据。

对于服务器端的防火墙来说,必须允许下面的通讯才能支持被动方式的FTP:

FTP服务器命令(21)端口接受客户端任意端口(客户端初始连接)FTP服务器命令(21)端口到客户端端口(>1023)(服务器响应客户端命令)FTP服务器数据端口(>1023)接受客户端端口(>1023)(客户端初始化数据连接到服务器指定的任意端口)FTP服务器数据端口(>1023)到客户端端口(>1023)(服务器发送ACK响应和数据到客户端的数据端口)

用图表示如下:

  FTP的主动和被动模式是什么

在第1步中,客户端的命令端口与服务器的命令端口建立连接,并发送命令“PASV”。然后在第2步中,服务器返回命令”PORT 2024″,告诉客户端(服务器)用哪个端口侦听数据连接。在第3步中,客户端初始化一个从自己的数据端口到服务器端指定的数据端口的数据连接。最后服务器在第4 步中给客户端的数据端口返回一个”ACK”响应。

被动方式的FTP解决了客户端的许多问题,但同时给服务器端带来了更多的问题。最大的问题是需要允许从任意远程终端到服务器高位端口的连接。幸运的是,许多FTP守护程序,包括流行的WU-FTPD允许管理员指定FTP服务器使用的端口范围。详细内容参看附录1。

第二个问题是客户端有的支持被动模式,有的不支持被动模式,必须考虑如何能支持这些客户端,以及为他们提供解决办法。例如,Solaris提供的FTP命令行工具就不支持被动模式,需要第三方的FTP客户端,比如ncftp。

随着WWW的广泛流行,许多人习惯用web浏览器作为FTP客户端。大多数浏览器只在访问ftp://这样的URL时才支持被动模式。这到底是好还是坏取决于服务器和防火墙的配置。

备注

有读者指出,当NAT(Network Address Translation)设备以主动模式访问FTP服务器时,由于NAT设备不会聪明的变更FTP包中的IP地址,从而导致无法访问服务器。

总结

下面的图表会帮助管理员们记住每种FTP方式是怎样工作的:

主动FTP:

命令连接:客户端 >1023端口 -> 服务器 21端口数据连接:客户端 >1023端口

被动FTP:

命令连接:客户端 >1023端口 -> 服务器 21端口数据连接:客户端 >1023端口 -> 服务器 >1023端口

主动FTP对FTP服务器的管理有利,但对客户端的管理不利。因为FTP服务器企图与客户端的高位随机端口建立连接,而这个端口很有可能被客户端的防火墙阻塞掉。被动FTP对FTP客户端的管理有利,但对服务器端的管理不利。因为客户端要与服务器端建立两个连接,其中一个连到一个高位随机端口,而这个端口很有可能被服务器端的防火墙阻塞掉。

幸运的是,有折衷的办法。既然FTP服务器的管理员需要他们的服务器有最多的客户连接,那么必须得支持被动FTP。我们可以通过为FTP服务器指定一个有限的端口范围来减小服务器高位端口的暴露。这样,不在这个范围的任何端口会被服务器的防火墙阻塞。虽然这没有消除所有针对服务器的危险,但它大大减少了危险。

关于“FTP的主动和被动模式是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

FTP的主动和被动模式是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

FTP的主动和被动模式是什么

这篇文章主要介绍“FTP的主动和被动模式是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“FTP的主动和被动模式是什么”文章能帮助大家解决问题。FTP(File Transfer Protocol
2023-06-27

FTP协议的主动模式与被动模式的区别详解

这篇文章主要讲解Ftp协议主动模式和被动模式的区别、以及FTP服务器的安装部署,需要的朋友可以参考下
2023-05-18

serv_u要关闭被动模式(PASV),使用PORT模式才能连接FTP的解决办法

使用 flashfxp 或传东西时必须要关闭被动模式,否则无法连接,连接FTP时客户端总是提示:PORT 模式成功, 请更新你的站点配置文件
2022-11-15

win11活动信号模式是什么

今天小编给大家分享一下win11活动信号模式是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。答:win11的活动信号模式
2023-07-02

DB2中的自动提交模式是什么

在DB2中,自动提交模式是一种数据库管理系统的配置选项,它确定了在执行数据库操作时是否自动提交这些操作。当自动提交模式开启时,每条SQL语句执行后都会自动提交该操作,即使在一个事务中执行多条SQL语句,也会分别提交每个操作,不会在一个事务中
DB2中的自动提交模式是什么
2024-03-07

FTP服务器的传输模式是什么

FTP服务器有两种传输模式:主动模式和被动模式。主动模式:在主动模式下,客户端在连接到服务器时会向服务器发出PORT命令,指示服务器连接到客户端的数据端口。然后服务器会主动连接到客户端指定的数据端口,进行数据传输。被动模式:在被动模式下,客
FTP服务器的传输模式是什么
2024-05-11

windows中安全模式启动和正常启动有什么区别

这篇文章给大家分享的是有关windows中安全模式启动和正常启动有什么区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是安全模式?安全模式是windows用于修复操作系统错误的专用模式,是一种不加载任何驱动
2023-06-28

云主机的计费模式是什么

云主机的计费模式通常有以下几种:1. 按需计费:根据实际使用时长和资源配置进行计费,灵活性较高,用户可以随时启动或停止云主机,并根据实际需求调整资源配置。用户只需支付实际使用的时间和资源费用。2. 包年包月:用户可以选择一段时间内预付费用,
2023-09-20

Redis的事件驱动模型是什么

这篇文章主要讲解了“Redis的事件驱动模型是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis的事件驱动模型是什么”吧!为什么 Redis 不使用基本的 Socket 编程模型?
2023-06-30

降噪模式和通透模式的区别是什么

降噪模式和通透模式的区别是:1、降噪模式旨在减少周围环境的噪音干扰,而通透模式允许外界声音传入耳机;2、降噪模式适用于需要在嘈杂环境中获得更好听音质或专注的场景,而通透模式对周围环境感知、与他人交流或需要注意安全的场景非常有用。本教程操作系
2023-08-15

redis主备模式搭建的步骤是什么

搭建Redis主备模式可以通过以下步骤完成:安装Redis:首先在主服务器和备服务器上安装Redis数据库。配置主服务器:在主服务器上修改Redis配置文件,找到并设置以下参数:将bind设置为主服务器的IP地址;将requirepass
redis主备模式搭建的步骤是什么
2024-05-22

MySQL中外键和主键的自动连接机制是什么?

MySQL中外键和主键的自动连接机制是通过建立外键约束来实现的。外键约束是一种关系约束,在一个表中的字段与另一个表中的字段建立关联,从而确保数据的一致性和完整性。主键是一个表中唯一标识每一行数据的字段,而外键则是另一个表中的主键,用于建立表
MySQL中外键和主键的自动连接机制是什么?
2024-03-15

windows默认的启动方式是什么

Windows默认的启动方式是通过引导管理器(Boot Manager)来加载操作系统。具体来说,当计算机启动时,BIOS或UEFI固件会首先执行自检程序,然后加载引导管理器。引导管理器负责在启动设备中查找并选择操作系统加载。在Window
2023-09-12

legacy和uefi启动指的是什么

这篇文章主要介绍“legacy和uefi启动指的是什么”,在日常操作中,相信很多人在legacy和uefi启动指的是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”legacy和uefi启动指的是什么”的疑
2023-03-13

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录