zoukankan      html  css  js  c++  java
  • 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中,命令连接和数据连接都由客户端,这样就可以解决从服务器到客户端的数据端口的入方向连接被防火墙过滤掉的问题。当开启一个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响应和数据到客户端的数据端口)

          

    参考:

    https://www.cnblogs.com/ajianbeyourself/p/7655464.html

  • 相关阅读:
    Photoshop 图文并茂常用快捷键
    程序员放松的8个好网站推荐
    Ehcache详细解读
    IT人士必去的10个网站
    [javascript]避免悲剧 密码生成器
    jQuery创建实例与原型继承揭秘
    [javascript]快速交换javascript变量的值
    [javascript]web216安全色拾色器colorpicker 支持浏览器边缘碰撞翻转(原生js)
    [Javascript]单例模式(singleton )
    duffsDevice 高速版
  • 原文地址:https://www.cnblogs.com/killerqi/p/10983423.html
Copyright © 2011-2022 走看看