這篇文章介紹另一個好用的抓包工具 Wireshark逊拍, 用來獲取網(wǎng)絡數(shù)據(jù)封包稽荧,包括 HTTP擦盾、TCP鳄袍、UDP 等網(wǎng)絡協(xié)議包窗怒。
記得大學的時候就學習過TCP的三次握手協(xié)議映跟,那時候只是知道蓄拣,雖然在書上看過很多TCP和UDP的資料,但是從來沒有真正見過這些數(shù)據(jù)包努隙, 老是感覺在云上飄一樣球恤,學得不踏實。有了wireshark就能截獲這些網(wǎng)絡數(shù)據(jù)包荸镊,可以清晰的看到數(shù)據(jù)包中的每一個字段咽斧。更能加深我們對網(wǎng)絡協(xié)議的理解。對我而言躬存, wireshark 是學習網(wǎng)絡協(xié)議最好的工具张惹。
閱讀目錄
wireshark介紹
wireshark不能做的
wireshark VS Fiddler
同類的其他工具
什么人會用到wireshark
wireshark 開始抓包
wireshark 窗口介紹
wireshark 顯示過濾
保存過濾
過濾表達式
封包列表(Packet List Pane)
封包詳細信息 (Packet Details Pane)
wireshark與對應的OSI七層模型
TCP包的具體內(nèi)容
實例分析TCP三次握手過程
wireshark介紹
wireshark的官方下載網(wǎng)站:?http://www.wireshark.org/
wireshark是非常流行的網(wǎng)絡封包分析軟件,功能十分強大岭洲⊥鸲海可以截取各種網(wǎng)絡封包,顯示網(wǎng)絡封包的詳細信息盾剩。
wireshark是開源軟件雷激,可以放心使用。 可以運行在Windows和Mac OS上告私。
使用wireshark的人必須了解網(wǎng)絡協(xié)議屎暇,否則就看不懂wireshark了。
Wireshark不能做的
為了安全考慮德挣,wireshark只能查看封包恭垦,而不能修改封包的內(nèi)容快毛,或者發(fā)送封包格嗅。
Wireshark VS Fiddler
Fiddler是在windows上運行的程序,專門用來捕獲HTTP唠帝,HTTPS的屯掖。
wireshark能獲取HTTP,也能獲取HTTPS襟衰,但是不能解密HTTPS贴铜,所以wireshark看不懂HTTPS中的內(nèi)容
總結(jié),如果是處理HTTP,HTTPS 還是用Fiddler,? 其他協(xié)議比如TCP,UDP 就用wireshark
同類的其他工具
微軟的network monitor
sniffer
什么人會用到wireshark
1. 網(wǎng)絡管理員會使用wireshark來檢查網(wǎng)絡問題
2. 軟件測試工程師使用wireshark抓包瀑晒,來分析自己測試的軟件
3. 從事socket編程的工程師會用wireshark來調(diào)試
4. 聽說绍坝,華為,中興的大部分工程師都會用到wireshark苔悦。
總之跟網(wǎng)絡相關(guān)的東西轩褐,都可能會用到wireshark.
wireshark 開始抓包
開始界面
wireshark是捕獲機器上的某一塊網(wǎng)卡的網(wǎng)絡包,當你的機器上有多塊網(wǎng)卡的時候玖详,你需要選擇一個網(wǎng)卡把介。
點擊Caputre->Interfaces.. 出現(xiàn)下面對話框勤讽,選擇正確的網(wǎng)卡。然后點擊”Start”按鈕, 開始抓包
Wireshark 窗口介紹
WireShark 主要分為這幾個界面
1. Display Filter(顯示過濾器)拗踢,? 用于過濾
2. Packet List Pane(封包列表)脚牍, 顯示捕獲到的封包, 有源地址和目標地址巢墅,端口號诸狭。 顏色不同,代表
3. Packet Details Pane(封包詳細信息), 顯示封包中的字段
4. Dissector Pane(16進制數(shù)據(jù))
5. Miscellanous(地址欄君纫,雜項)
Wireshark 顯示過濾
使用過濾是非常重要的作谚, 初學者使用wireshark時,將會得到大量的冗余信息庵芭,在幾千甚至幾萬條記錄中妹懒,以至于很難找到自己需要的部分。搞得暈頭轉(zhuǎn)向双吆。
過濾器會幫助我們在大量的數(shù)據(jù)中迅速找到我們需要的信息眨唬。
過濾器有兩種,一種是顯示過濾器好乐,就是主界面上那個匾竿,用來在捕獲的記錄中找到所需要的記錄
一種是捕獲過濾器,用來過濾捕獲的封包蔚万,以免捕獲太多的記錄岭妖。 在Capture -> Capture Filters 中設置
保存過濾
在Filter欄上,填好Filter的表達式后反璃,點擊Save按鈕昵慌, 取個名字。比如”Filter 102″,
Filter欄上就多了個”Filter 102″ 的按鈕淮蜈。
過濾表達式的規(guī)則
表達式規(guī)則
1. 協(xié)議過濾
比如TCP斋攀,只顯示TCP協(xié)議。
2. IP 過濾
比如 ip.src ==192.168.1.102 顯示源地址為192.168.1.102梧田,
ip.dst==192.168.1.102, 目標地址為192.168.1.102
3. 端口過濾
tcp.port ==80,? 端口為80的
tcp.srcport == 80,? 只顯示TCP協(xié)議的愿端口為80的淳蔼。
4. Http模式過濾
http.request.method==”GET”,?? 只顯示HTTP GET方法的。
5. 邏輯運算符為 AND/ OR
常用的過濾表達式
封包列表的面板中顯示裁眯,編號鹉梨,時間戳,源地址穿稳,目標地址存皂,協(xié)議,長度司草,以及封包信息艰垂。 你可以看到不同的協(xié)議用了不同的顏色顯示泡仗。封包列表(Packet List Pane)
你也可以修改這些顯示顏色的規(guī)則,? View ->Coloring Rules.
封包詳細信息 (Packet Details Pane)
這個面板是我們最重要的猜憎,用來查看協(xié)議中的每一個字段娩怎。
各行信息分別為:
Frame:???物理層的數(shù)據(jù)幀概況
Ethernet?II:?數(shù)據(jù)鏈路層以太網(wǎng)幀頭部信息
Internet Protocol Version 4:?互聯(lián)網(wǎng)層IP包頭部信息
Transmission Control Protocol:??傳輸層T的數(shù)據(jù)段頭部信息,此處是TCP
Hypertext Transfer Protocol:??應用層的信息胰柑,此處是HTTP協(xié)議
wireshark與對應的OSI七層模型
TCP包的具體內(nèi)容
從下圖可以看到wireshark捕獲到的TCP包中的每個字段截亦。
實例分析TCP三次握手過程
看到這, 基本上對wireshak有了初步了解柬讨, 現(xiàn)在我們看一個TCP三次握手的實例
三次握手過程為
這圖我都看過很多遍了崩瓤, 這次我們用wireshark實際分析下三次握手的過程。
打開wireshark, 打開瀏覽器輸入?http://www.cnblogs.com/tankxiao
在wireshark中輸入http過濾踩官, 然后選中GET /tankxiao HTTP/1.1的那條記錄却桶,右鍵然后點擊”Follow TCP Stream”,
這樣做的目的是為了得到與瀏覽器打開網(wǎng)站相關(guān)的數(shù)據(jù)包,將得到如下圖
圖中可以看到wireshark截獲到了三次握手的三個數(shù)據(jù)包蔗牡。第四個包才是HTTP的颖系, 這說明HTTP的確是使用TCP建立連接的。
第一次握手數(shù)據(jù)包
客戶端發(fā)送一個TCP辩越,標志位為SYN嘁扼,序列號為0, 代表客戶端請求建立連接黔攒。 如下圖
第二次握手的數(shù)據(jù)包
服務器發(fā)回確認包, 標志位為 SYN,ACK. 將確認序號(Acknowledgement Number)設置為客戶的I S N加1以.即0+1=1, 如下圖
第三次握手的數(shù)據(jù)包
客戶端再次發(fā)送確認包(ACK) SYN標志位為0,ACK標志位為1.并且把服務器發(fā)來ACK的序號字段+1,放在確定字段中發(fā)送給對方.并且在數(shù)據(jù)段放寫ISN的+1, 如下圖:
就這樣通過了TCP三次握手趁啸,建立了連接