码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2018-01-18 18:01:20      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:blog   控制进程   比较   客户端   数据   服务   http   inf   数据包   

玩明白了以太网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种模式

标签:blog   控制进程   比较   客户端   数据   服务   http   inf   数据包   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!