FTP 通信抓包

繼上一篇《CentOS 6.5 手動搭建FTP服務(wù)器--vsftpd》,我們再來看一下FTP通信的過程是怎么樣的。這里我們使用了最流行的網(wǎng)絡(luò)抓包工具:Wireshark,版本是2.4.2。我們把它安裝在了client端,也就是實(shí)驗(yàn)機(jī)上的Windows虛擬機(jī)。我們把整個操作過程所觸發(fā)的所有通信包都抓了下來,從底層來窺探下FTP實(shí)現(xiàn)機(jī)制 -- 登錄FTP服務(wù)器,運(yùn)行l(wèi)s命令查看文件列表,并用get命令下載服務(wù)器上的一個文件,最后退出FTP登錄。

FTP Server IP: 192.168.111.15

FTP Client IP: 192.168.111.13

分析之前還要免費(fèi)做個安利,公司內(nèi)的網(wǎng)絡(luò)大牛的一本抓包分析圖書《Wireshark網(wǎng)絡(luò)分析就是這么簡單》,本文從中受到了很大啟發(fā)也做了些借鑒,侵權(quán)即刪。


1. ARP

同一網(wǎng)段內(nèi)的主機(jī)在二層網(wǎng)絡(luò)需要Mac地址來通信,client端發(fā)起了ARP廣播查詢,查詢server的mac地址。Server響應(yīng)正確的mac地址

2. TCP 三次握手

Client端發(fā)起與Server的TCP通信

3. FTP 服務(wù)器應(yīng)答FTP請求,并與client交互識別身份完成登錄

上述三個包展現(xiàn)的是TCP連接建立完成后,F(xiàn)TP server返回的應(yīng)答以及client的ACK。透過wireshark的解析,我們看到Response 220的具體含義是:Service ready for new user(220)

以上是身份識別過程的包,到此為止這也是TCP登錄過程中所有的通信包,前提是你輸入完用戶名密碼后沒有做其他的操作,比如ls查看文件列表。可以看到,每一個TCP請求或者應(yīng)答都會伴隨一個TCP的ACK包


4. 用戶請求文件列表

18 - 20:

client和server交互通信所有的端口, client端口的計算方法為192x256+42 = 49194。這里沒有協(xié)商任何有關(guān)server端口的信息,那么server端口是怎么來的呢?答案在FTP server的配置文件中(/etc/vsftpd/vsftpd.conf):

connect_from_port_20=YES

21:

Client 發(fā)出ls命令

22 - 24:

Server發(fā)起與client的三次握手

25 - 26:

Server應(yīng)答FTP請求,返回ls命令的data

27,28,31,32:

Server應(yīng)答完成立即斷開TCP連接,這里是4次揮手的過程

29 - 30:

這里是client返回ACK應(yīng)答Server發(fā)來的文件列表數(shù)據(jù),包括了FTP和TCP兩個ACK包。值得注意的是,雖然這兩個包出現(xiàn)在TCP4次揮手過程中,并不代表這兩個包和TCP斷開連接有關(guān)系,實(shí)際上,TCP server發(fā)送完數(shù)據(jù)后會立刻斷開連接。這里的兩個包實(shí)際上是“控制連接”的兩個包,仔細(xì)觀察可以看到,通信端口是49131->21。而“數(shù)據(jù)連接”通信是在49194和20之間。

可能到了這里讀者也已經(jīng)看了出來,F(xiàn)TP的工作方式分為兩部分,一部分是控制鏈接,用于傳輸控制信息,具體工作在建立鏈接過程;而另一個部分則是數(shù)據(jù)鏈接,每當(dāng)client請求數(shù)據(jù),client和server就會重新建立一個TCP鏈接用于數(shù)據(jù)傳輸,數(shù)據(jù)傳輸完成后,這個TCP鏈接就會被斷開。其中,控制鏈接的TCP通信是由client發(fā)起,而數(shù)據(jù)鏈接的FTP通信則又server端發(fā)起。而每次數(shù)據(jù)傳輸,都需要控制鏈接和數(shù)據(jù)鏈接的共同協(xié)作完成,數(shù)據(jù)鏈接完成數(shù)據(jù)交互,控制鏈接也要做傳輸完成應(yīng)答。


5. 用戶請求文件

這三個包體現(xiàn)的是用戶切換至binary傳輸模式發(fā)生的網(wǎng)絡(luò)通信。client請求,server應(yīng)答,client返回ACK。

同上面第四部分用戶執(zhí)行l(wèi)s命令相同,當(dāng)用戶發(fā)出 get b.txt命令后,首先是client和server交互通信端口信息(38-40)。然后是server利用協(xié)商出的新端口發(fā)起和client的新的TCP鏈接(41-43),并傳輸數(shù)據(jù)(44-45)。數(shù)據(jù)傳輸完成后斷開這個TCP數(shù)據(jù)鏈接(46-47, 50-51)。而TCP的控制鏈接也對傳輸完成做了確認(rèn)(48-49)。


6. Client斷開FTP鏈接

當(dāng)用戶在終端敲出bye命令后,我們看到client發(fā)出了一個FTP包,請求QUIT FTP鏈接,隨即server友好地回應(yīng)了一句Goodbye。之后又是sever發(fā)起的TCP四次揮手?jǐn)嚅_控制鏈接。所以,控制鏈接是伴隨整個FTP鏈接生命周期的。至此,整個FTP通信過程分析完畢,是不是感覺FTP是個比較簡潔的協(xié)議呢?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,489評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,290評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,510評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,866評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,036評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,585評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,331評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,536評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,754評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,273評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,505評論 2 379

推薦閱讀更多精彩內(nèi)容

  • 國家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 11,074評論 6 13
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,826評論 18 139
  • 網(wǎng)絡(luò)概念第一天 兩臺電腦怎么通過網(wǎng)絡(luò)傳輸數(shù)據(jù)?怎樣才能知道傳輸?shù)氖菙?shù)據(jù)?誰摸過網(wǎng)線? 看電影,怎么看的?通過電流,...
    小吖朱閱讀 1,578評論 0 1
  • 轉(zhuǎn)。。。。。。。。 SOCKET,TCP/UDP,HTTP,FTP (一)TCP/UDP,SOCKET,HTTP,...
    zeqinjie閱讀 3,308評論 1 53
  • 簡介 用簡單的話來定義tcpdump,就是:dump the traffic on a network,根據(jù)使用者...
    保川閱讀 5,981評論 1 13