Wireshark基本介紹和學習TCP三向交握,wiresharktcp

來源:互聯網
上載者:User

Wireshark基本介紹和學習TCP三向交握,wiresharktcp

這篇文章介紹另一個好用的抓包工具wireshark, 用來擷取網路資料封包,包括http,TCP,UDP,等網路通訊協定包。

記得大學的時候就學習過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/

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基本介紹和學習TCP三向交握,後續繼續整理相關知識,謝謝大家對本站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.