首页 > 其他 > 详细

[svc]ftp协议数据连接的2种模式

时间:2018-01-18 17:47:11      阅读:227      评论:0      收藏:0      [点我收藏+]

玩明白了以太网2的二层数据格式, ip格式 tcp/udp个时候, 需要玩一玩一些有用的基于这些已上的协议数据了. 如 dhcp ftp等.比较有趣.

ftp协议

分控制连接21端口 和数据连接 20端口

数据连接站在服务端角度来讲分两种模式: 主动模式(服务端主动用自己的20端口去连客户端,适合防火墙)
被动模式(服务端被动等客户端来连服务端的一个随机端口.)

技术分享图片

每个协议都有控制层面(对应控制报文),和数据层面(对应的传输数据,有些只有控制层面,如dhcp不需要传数据)

FTP服务端会监听2个端口, 控制进程20,数据进程21(主动模式)

数据连接,站在服务器角度,有2种模式:
    主动模式:ftp server从20端口主动向客户端发起连接,由于源端口固定,所以适用于模式防火墙模式.
    被动模式:ftp server被动等待客户端来连我的这个端口(控制连接后会告知会将passive ip/port告知了客户端)
一般情况下默认都是被动模式

ftp两种模式

原图和两枚ftp数据包: https://github.com/lannyMa/scripts/tree/master/pkgs/ftp
技术分享图片

主动模式数据交互过程

14.1 客户端 14.128服务端

  • 建立控制连接,3次握手, 客户端连服务端21端口
    技术分享图片

  • 待连接建立后,客户端告知服务端 active ip/port
    技术分享图片

  • 服务端主动和客户端建立数据连接(站在服务端角度,是服务端主动去找客户端)
    技术分享图片

  • 传输数据
    技术分享图片

  • 断开数据连接
    技术分享图片

  • 断开控制连接
    技术分享图片

被动模式数据交互过程

  • 客户端主动去和服务端建立控制连接
    技术分享图片

  • 服务端告知客户端passive mode /ip/port
    技术分享图片

  • 客户端主动去和服务端建立数据连接(站在服务端角度,是服务端被动等客户端)
    技术分享图片

  • 客户端和服务端之间断开数据连接
    技术分享图片

  • 客户端和服务端之间断开控制连接
    技术分享图片

[svc]ftp协议数据连接的2种模式

原文:https://www.cnblogs.com/iiiiher/p/8311458.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!