Wireshark基本介紹和TCP三次握手

轉自:http://www.cnblogs.com/TankXiao/archive/2012/10/10/2711777.htmlhtml

以前寫過一篇博客:用 Fiddler 來調試HTTP,HTTPS編程

這篇文章介紹還有一個好用的抓包工具wireshark。 用來獲取網絡數據封包。包含http,TCP,UDP,等網絡協議包。windows

記得大學的時候就學習過TCP的三次握手協議,那時候僅僅是知道,儘管在書上看過很是多TCP和UDP的資料,但是歷來沒有真正見過這些數據包, 總是感受在雲上飄同樣,學得不踏實。有了wireshark就能截獲這些網絡數據包,可以清晰的看到數據包中的每一個字段。更能加深咱們對網絡協議的理解。瀏覽器


對我而言。 wireshark 是學習網絡協議最好的工具。安全

 

閱讀文件夾

網絡

  1. wireshark介紹
  2. wireshark不能作的
  3. wireshark VS Fiddler
  4. 同類的其它工具
  5. 什麼人會用到wireshark
  6. wireshark 開始抓包
  7. wireshark 窗體介紹
  8. wireshark 顯示過濾
  9. 保存過濾
  10. 過濾表達式
  11. 封包列表(Packet List Pane)
  12. 封包具體信息 (Packet Details Pane)
  13. wireshark與相應的OSI七層模型
  14. TCP包的具體內容
  15. 實例分析TCP三次握手過程

 

wireshark介紹

wireshark的官方下載站點: http://www.wireshark.org/socket

wireshark是很流行的網絡封包分析軟件,功能十分強大。tcp

可以截取各類網絡封包,顯示網絡封包的具體信息。工具

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. 軟件測試project師使用wireshark抓包,來分析本身測試的軟件

3. 從事socket編程的project師會用wireshark來調試

4. 據說。華爲,中興的大部分project師都會用到wireshark。

 

總之跟網絡相關的東西。均可能會用到wireshark.

wireshark 開始抓包

開始界面

wireshark是捕獲機器上的某一塊網卡的網絡包,當你的機器上有多塊網卡的時候。你需要選擇一個網卡。

點擊Caputre->Interfaces.. 出現如下對話框,選擇正確的網卡。

而後點擊"Start"button, 開始抓包

 

Wireshark 窗體介紹

 

WireShark 主要分爲這幾個界面

1. Display Filter(顯示過濾器),  用於過濾

2. Packet List Pane(封包列表), 顯示捕獲到的封包, 有源地址和目標地址,port號。

顏色不一樣。表明

3. Packet Details Pane(封包具體信息), 顯示封包中的字段

4. Dissector Pane(16進制數據)

5. Miscellanous(地址欄。雜項)

 

Wireshark 顯示過濾

使用過濾是很是重要的, 剛開始學習的人使用wireshark時,將會獲得大量的冗餘信息,在幾千甚至幾萬條記錄中,以致於很是難找到本身需要的部分。

搞得暈頭轉向。

過濾器會幫助咱們在大量的數據中迅速找到咱們需要的信息。

過濾器有兩種,

一種是顯示過濾器,就是主界面上那個,用來在捕獲的記錄中找到所需要的記錄

一種是捕獲過濾器,用來過濾捕獲的封包,以避免捕獲太多的記錄。

在Capture -> Capture Filters 中設置

 

保存過濾

在Filter欄上,填好Filter的表達式後,點擊Savebutton。 取個名字。比方"Filter 102",

Filter欄上就多了個"Filter 102" 的button。

過濾表達式的規則

表達式規則

 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. port過濾

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創建鏈接的。

 

第一次握手數據包

client發送一個TCP。標誌位爲SYN。序列號爲0, 表明client請求創建鏈接。 例如如下圖

第二次握手的數據包

server發回確認包, 標誌位爲 SYN,ACK. 將確認序號(Acknowledgement Number)設置爲客戶的I S N加1以.即0+1=1, 例如如下圖

第三次握手的數據包

client再次發送確認包(ACK) SYN標誌位爲0,ACK標誌位爲1.並且把server發來ACK的序號字段+1,放在肯定字段中發送給對方.並且在數據段放寫ISN的+1, 例如如下圖:

 就這樣經過了TCP三次握手,創建了鏈接

相關文章
相關標籤/搜索