日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

抓包工具Wireshark基本介绍和学习TCP三次握手

發布時間:2025/4/16 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 抓包工具Wireshark基本介绍和学习TCP三次握手 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文鏈接:http://www.cnblogs.com/TankXiao/archive/2012/10/10/2711777.html#threehand,肖佳

之前寫過一篇博客:用 Fiddler 來調試HTTP,HTTPS。 這篇文章介紹另一個好用的抓包工具wireshark, 用來獲取網絡數據封包,包括http,TCP,UDP,等網絡協議包。

記得大學的時候就學習過TCP的三次握手協議,那時候只是知道,雖然在書上看過很多TCP和UDP的資料,但是從來沒有真正見過這些數據包, 老是感覺在云上飄一樣,學得不踏實。有了wireshark就能截獲這些網絡數據包,可以清晰的看到數據包中的每一個字段。更能加深我們對網絡協議的理解。

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

1. wireshark介紹

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

wireshark是非常流行的網絡封包分析軟件,功能十分強大。可以截取各種網絡封包,顯示網絡封包的詳細信息。

wireshark是開源軟件,可以放心使用。 可以運行在Windows和Mac OS上。

使用wireshark的人必須了解網絡協議,否則就看不懂wireshark了。

2. Wireshark不能做的

為了安全考慮,wireshark只能查看封包,而不能修改封包的內容,或者發送封包。

3. Wireshark VS Fiddler

Fiddler是在windows上運行的程序,專門用來捕獲HTTP,HTTPS的。

wireshark能獲取HTTP,也能獲取HTTPS,但是不能解密HTTPS,所以wireshark看不懂HTTPS中的內容

總結,如果是處理HTTP,HTTPS 還是用Fiddler, 其他協議比如TCP,UDP 就用wireshark

4. 同類的其他工具

微軟的network monitor,sniffer

5. 什么人會用到wireshark

  • 網絡管理員會使用wireshark來檢查網絡問題
  • 軟件測試工程師使用wireshark抓包,來分析自己測試的軟件
  • 從事socket編程的工程師會用wireshark來調試
  • 聽說,華為,中興的大部分工程師都會用到wireshark

總之跟網絡相關的東西,都可能會用到wireshark

6. wireshark 開始抓包

開始界面

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

點擊Caputre->Interfaces.. 出現下面對話框,選擇正確的網卡。然后點擊”Start”按鈕, 開始抓包

7. Wireshark 窗口介紹

WireShark 主要分為這幾個界面

  • Display Filter(顯示過濾器), 用于過濾
  • Packet List Pane(封包列表), 顯示捕獲到的封包, 有源地址和目標地址,端口號。 顏色不同,代表
  • Packet Details Pane(封包詳細信息), 顯示封包中的字段
  • Dissector Pane(16進制數據)
  • Miscellanous(地址欄,雜項)

8. Wireshark 顯示過濾

使用過濾是非常重要的, 初學者使用wireshark時,將會得到大量的冗余信息,在幾千甚至幾萬條記錄中,以至于很難找到自己需要的部分。搞得暈頭轉向。過濾器會幫助我們在大量的數據中迅速找到我們需要的信息。

過濾器有兩種:

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

一種是捕獲過濾器,用來過濾捕獲的封包,以免捕獲太多的記錄。 在Capture -> Capture Filters 中設置

9. 保存過濾

在Filter欄上,填好Filter的表達式后,點擊Save按鈕, 取個名字。比如”Filter 102”

Filter欄上就多了個”Filter 102” 的按鈕

10. 過濾表達式的規則

過濾表達式的規則

表達式規則規則說明
協議過濾比如TCP,只顯示TCP協議
IP 過濾比如 ip.src ==192.168.1.102 顯示源地址為192.168.1.102,ip.dst==192.168.1.102,目標地址為192.168.1.102
端口過濾tcp.port ==80, 端口為80的; tcp.srcport == 80, 只顯示TCP協議的愿端口為80的
Http模式過濾http.request.method==”GET”, 只顯示HTTP GET方法的
邏輯運算符AND/ OR

常用的過濾表達式

過濾表達式用途
http只查看HTTP協議的記錄
ip.src ==192.168.1.102過濾源ip地址是192.168.1.102
ip.dst==192.168.1.102過濾目標ip地址是192.168.1.102
ip.src ==192.168.1.102 or ip.dst==192.168.1.102源地址或者目標地址是192.168.1.102
http.request.method==”GET”過濾get請求
http.request.method==”POST”過濾post請求
http.request.method==”GET” and ip.dst==192.168.1.102

11. 封包列表(Packet List Pane)

封包列表的面板中顯示,編號,時間戳,源地址,目標地址,協議,長度,以及封包信息。 你可以看到不同的協議用了不同的顏色顯示。

你也可以修改這些顯示顏色的規則, View ->Coloring Rules.

12. 封包詳細信息 (Packet Details Pane)

這個面板是我們最重要的,用來查看協議中的每一個字段。各行信息分別為

  • Frame: 物理層的數據幀概況
  • Ethernet II: 數據鏈路層以太網幀頭部信息
  • Internet Protocol Version 4: 互聯網層IP包頭部信息
  • Transmission Control Protocol: 傳輸層T的數據段頭部信息,此處是TCP
  • Hypertext Transfer Protocol: 應用層的信息,此處是HTTP協議

13. wireshark與對應的OSI七層模型

14. TCP包的具體內容

從下圖可以看到wireshark捕獲到的TCP包中的每個字段。

15. 實例分析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三次握手的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。