Wireshark 基本介紹和學習 TCP 三次握手
這篇文章介紹另一個好用的抓包工具 Wireshark, 用來獲取網路資料封包,包括 HTTP、TCP、UDP 等網路協議包。
記得大學的時候就學習過TCP的三次握手協議,那時候只是知道,雖然在書上看過很多TCP和UDP的資料,但是從來沒有真正見過這些資料包, 老是感覺在雲上飄一樣,學得不踏實。有了wireshark就能截獲這些網路資料包,可以清晰的看到資料包中的每一個欄位。更能加深我們對網路協議的理解。對我而言, wireshark 是學習網路協議最好的工具。
閱讀目錄
- wireshark介紹
- wireshark不能做的
- wireshark VS Fiddler
- 同類的其他工具
- 什麼人會用到wireshark
- wireshark 開始抓包
- wireshark 視窗介紹
- wireshark 顯示過濾
- 儲存過濾
- 過濾表示式
- 封包列表(Packet List Pane)
- 封包詳細資訊 (Packet Details Pane)
- wireshark與對應的OSI七層模型
- TCP包的具體內容
- 例項分析TCP三次握手過程
wireshark介紹
wireshark的官方下載網站: http://www.wireshark.org/
wireshark是非常流行的網路封包分析軟體,功能十分強大。可以擷取各種網路封包,顯示網路封包的詳細資訊。
wireshark是開源軟體,可以放心使用。 可以執行在Windows和Mac OS上。
使用wireshark的人必須瞭解網路協議,否則就看不懂wireshark了。
Wireshark不能做的
為了安全考慮,wireshark只能檢視封包,而不能修改封包的內容,或者傳送封包。
Wireshark VS Fiddler
Fiddler是在windows上執行的程式,專門用來捕獲HTTP,HTTPS的。
wireshark能獲取HTTP,也能獲取HTTPS,但是不能解密HTTPS,所以wireshark看不懂HTTPS中的內容
總結,如果是處理HTTP,HTTPS 還是用Fiddler, 其他協議比如TCP,UDP 就用wireshark
同類的其他工具
微軟的network monitor
sniffer
什麼人會用到wireshark
1. 網路管理員會使用wireshark來檢查網路問題
2. 軟體測試工程師使用wireshark抓包,來分析自己測試的軟體
3. 從事socket程式設計的工程師會用wireshark來除錯
4. 聽說,華為,中興的大部分工程師都會用到wireshark。
總之跟網路相關的東西,都可能會用到wireshark.
wireshark 開始抓包
開始介面
wireshark是捕獲機器上的某一塊網路卡的網路包,當你的機器上有多塊網路卡的時候,你需要選擇一個網路卡。
點選Caputre->Interfaces.. 出現下面對話方塊,選擇正確的網路卡。然後點選”Start”按鈕, 開始抓包
Wireshark 視窗介紹
WireShark 主要分為這幾個介面
1. Display Filter(顯示過濾器), 用於過濾
2. Packet List Pane(封包列表), 顯示捕獲到的封包, 有源地址和目標地址,埠號。 顏色不同,代表
3. Packet Details Pane(封包詳細資訊), 顯示封包中的欄位
4. Dissector Pane(16進位制資料)
5. Miscellanous(位址列,雜項)
Wireshark 顯示過濾
使用過濾是非常重要的, 初學者使用wireshark時,將會得到大量的冗餘資訊,在幾千甚至幾萬條記錄中,以至於很難找到自己需要的部分。搞得暈頭轉向。
過濾器會幫助我們在大量的資料中迅速找到我們需要的資訊。
過濾器有兩種,
一種是顯示過濾器,就是主介面上那個,用來在捕獲的記錄中找到所需要的記錄
一種是捕獲過濾器,用來過濾捕獲的封包,以免捕獲太多的記錄。 在Capture -> Capture Filters 中設定
儲存過濾
在Filter欄上,填好Filter的表示式後,點選Save按鈕, 取個名字。比如”Filter 102″,
Filter欄上就多了個”Filter 102″ 的按鈕。
過濾表示式的規則
表示式規則
1. 協議過濾
比如TCP,只顯示TCP協議。
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協議的願埠為80的。
4. Http模式過濾
http.request.method==”GET”, 只顯示HTTP GET方法的。
5. 邏輯運算子為 AND/ OR
常用的過濾表示式
過濾表示式 | 用途 |
http | 只檢視HTTP協議的記錄 |
ip.src ==192.168.1.102 or ip.dst==192.168.1.102 | 源地址或者目標地址是192.168.1.102 |
封包列表(Packet List Pane)
封包列表的皮膚中顯示,編號,時間戳,源地址,目標地址,協議,長度,以及封包資訊。 你可以看到不同的協議用了不同的顏色顯示。
你也可以修改這些顯示顏色的規則, View ->Coloring Rules.
封包詳細資訊 (Packet Details Pane)
這個皮膚是我們最重要的,用來檢視協議中的每一個欄位。
各行資訊分別為
Frame: 物理層的資料幀概況
Ethernet II: 資料鏈路層乙太網幀頭部資訊
Internet Protocol Version 4: 網際網路層IP包頭部資訊
Transmission Control Protocol: 傳輸層T的資料段頭部資訊,此處是TCP
Hypertext Transfer Protocol: 應用層的資訊,此處是HTTP協議
wireshark與對應的OSI七層模型
TCP包的具體內容
從下圖可以看到wireshark捕獲到的TCP包中的每個欄位。
例項分析TCP三次握手過程
看到這, 基本上對wireshak有了初步瞭解, 現在我們看一個TCP三次握手的例項
三次握手過程為
這圖我都看過很多遍了, 這次我們用wireshark實際分析下三次握手的過程。
開啟wireshark, 開啟瀏覽器輸入 http://www.cnblogs.com/tankxiao
在wireshark中輸入http過濾, 然後選中GET /tankxiao HTTP/1.1的那條記錄,右鍵然後點選”Follow TCP Stream”,
這樣做的目的是為了得到與瀏覽器開啟網站相關的資料包,將得到如下圖
圖中可以看到wireshark截獲到了三次握手的三個資料包。第四個包才是HTTP的, 這說明HTTP的確是使用TCP建立連線的。
第一次握手資料包
客戶端傳送一個TCP,標誌位為SYN,序列號為0, 代表客戶端請求建立連線。 如下圖
第二次握手的資料包
伺服器發回確認包, 標誌位為 SYN,ACK. 將確認序號(Acknowledgement Number)設定為客戶的I S N加1以.即0+1=1, 如下圖
第三次握手的資料包
客戶端再次傳送確認包(ACK) SYN標誌位為0,ACK標誌位為1.並且把伺服器發來ACK的序號欄位+1,放在確定欄位中傳送給對方.並且在資料段放寫ISN的+1, 如下圖:
就這樣通過了TCP三次握手,建立了連線
擴充套件閱讀:
- 一站式學習Wireshark(一):Wireshark基本用法
- 一站式學習Wireshark(二):應用Wireshark觀察基本網路協議
- 一站式學習Wireshark(三):應用Wireshark IO圖形工具分析資料流
- 一站式學習Wireshark(四):網路效能排查之TCP重傳與重複ACK
- 一站式學習Wireshark(五):TCP視窗與擁塞處理
- 一站式學習Wireshark(六):狙擊網路高延時點
- 一站式學習Wireshark(七):Statistics統計工具功能詳解與應用
- 一站式學習Wireshark(八):應用Wireshark過濾條件抓取特定資料流
相關文章
- Wireshark基本介紹和學習TCP三次握手TCP
- Wireshark除錯TCP三次握手流程除錯TCP
- 用 Wireshark 圖解 TCP 三次握手圖解TCP
- TCP三次握手四次揮手介紹TCP
- Wireshark抓包分析TCP“三次握手,四次揮手”TCP
- Wireshark捕獲理解TCP三次握手四次斷開TCP
- 跟著動畫學習 TCP 三次握手和四次揮手動畫TCP
- tcp三次握手和SYN攻擊TCP
- TCP三次握手原理TCP
- 跟著動畫來學習TCP三次握手和四次揮手動畫TCP
- TCP 的 三次握手 四次握手TCP
- TCP三次握手和四次揮手TCP
- 跟著動畫學TCP三次握手和四次揮手動畫TCP
- TCP的三次握手過程TCP
- 自己理解的TCP三次握手TCP
- TCP三次握手和四次揮手理解TCP
- TCP三次握手四次分手TCP
- TCP協議 連線三次握手TCP協議
- TCP建立連線三次握手和釋放連線四次握手TCP
- 「真香警告」重學TCP/IP 協議 與三次握手TCP協議
- TCP:三次握手、四次握手、backlog及其他TCP
- WireShark抓包分析以及對TCP/IP三次握手與四次揮手的分析TCP
- 簡述TCP三次握手和四次揮手TCP
- TCP戀愛史:三次握手和四次分手TCP
- TCP三次握手四次揮手TCP
- TCP三次握手&四次揮手TCP
- 面試最常問的tcp三次握手策略面試TCP
- TCP/IP 為什麼要三次握手TCP
- TCP 三次握手四次揮手TCP
- 說說TCP的三次握手和四次揮手TCP
- 圖解TCP的三次握手和四次揮手圖解TCP
- TCP協議的三次握手和四次揮手TCP協議
- TCP 三次握手原理以及半連線和全連線TCP
- TCP 三次握手和四次揮手及其狀態TCP
- TCP協議三次握手連線四次握手斷開和DOS攻擊TCP協議
- 在TCP三次握手後插入偽造的TCP包(轉)TCP
- TCP 三次握手 與 四次揮手TCP
- TCP 、 UDP、三次握手、四次揮手TCPUDP