日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

[轉帖]抓包工具wireshark

liguoquan
2024年10月12日 15:51 本文熱度 977
:[轉帖]抓包工具wireshark


抓包工具wireshark

一、wireshark是什么?

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

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

二、Wireshark常用應用場景

1. 網絡管理員會使用wireshark來檢查網絡問題

2. 軟件測試工程師使用wireshark抓包,來分析自己測試的軟件

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

4. 運維人員用于日常工作,應急響應等等

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

三、Wireshark抓包原理

Wireshark使用WinPCAP作為接口,直接與網卡進行數據報文交換。

Wireshark使用的環境大致分為兩種,一種是電腦直連網絡的單機環境,另外一種就是應用比較多的網絡環境,即連接交換機的情況。

「單機情況」下,Wireshark直接抓取本機網卡的網絡流量;

「交換機情況」下,Wireshark通過端口鏡像、ARP欺騙等方式獲取局域網中的網絡流量。

端口鏡像:利用交換機的接口,將局域網的網絡流量轉發到指定電腦的網卡上。

ARP欺騙:交換機根據MAC地址轉發數據,偽裝其他終端的MAC地址,從而獲取局域網的網絡流量。

四、Wireshark軟件安裝

軟件下載路徑:

https://www.wireshark.org/

按照系統版本選擇下載,下載完成后,按照軟件提示一路Next安裝。

五、Wireshark抓包示例

先介紹一個使用wireshark工具抓取ping命令操作的示例,可以上手操作感受一下抓包的具體過程。

1、打開wireshark,主界面如下:

2、選擇菜單欄上 捕獲 -> 選項,勾選WLAN網卡。這里需要根據各自電腦網卡使用情況選擇,簡單的辦法可以看使用的IP對應的網卡。點擊Start,啟動抓包。 

 3、wireshark啟動后,wireshark處于抓包狀態中。

 4、執行需要抓包的操作,如在cmd窗口下執行ping www.baidu.com。

 5、操作完成后相關數據包就抓取到了,可以點擊 停止捕獲分組 按鈕。

 6、為避免其他無用的數據包影響分析,可以通過在過濾欄設置過濾條件進行數據包列表過濾,獲取結果如下。

說明:ip.addr == 183.232.231.172 and icmp 表示只顯示ICPM協議且主機IP為183.232.231.172的數據包。說明:協議名稱icmp要小寫。

 7、wireshark抓包完成,并把本次抓包或者分析的結果進行保存,就這么簡單。關于wireshark顯示過濾條件、抓包過濾條件、以及如何查看數據包中的詳細內容在后面介紹。

六、Wireshakr抓包界面介紹

Wireshark 的主界面包含6個部分:

菜單欄:用于調試、配置

工具欄:常用功能的快捷方式

過濾欄:指定過濾條件,過濾數據包

數據包列表:核心區域,每一行就是一個數據包

數據包詳情:數據包的詳細數據

數據包字節:數據包對應的字節流,二進制

說明:數據包列表區中不同的協議使用了不同的顏色區分。協議顏色標識定位在菜單欄 視圖 --> 著色規則。如下所示

WireShark 主要分為這幾個界面

1. Display Filter(顯示過濾器)

用于設置過濾條件進行數據包列表過濾。菜單路徑:分析 --> Display Filters。

2. Packet List Pane(數據包列表)

顯示捕獲到的數據包,每個數據包包含編號,時間戳,源地址,目標地址,協議,長度,以及數據包信息。不同協議的數據包使用了不同的顏色區分顯示。

3. Packet Details Pane(數據包詳細信息)

在數據包列表中選擇指定數據包,在數據包詳細信息中會顯示數據包的所有詳細信息內容。數據包詳細信息面板是最重要的,用來查看協議中的每一個字段。各行信息分別為

(1)Frame:   物理層的數據幀概況

(2)Ethernet II: 數據鏈路層以太網幀頭部信息

(3)Internet Protocol Version 4: 互聯網層IP包頭部信息

(4)Transmission Control Protocol:  傳輸層T的數據段頭部信息,此處是TCP

(5)Hypertext Transfer Protocol:  應用層的信息,此處是HTTP協議

TCP包的具體內容

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

 

4. Dissector Pane(數據包字節區)

報文原始內容。

七、Wireshark過濾器設置

初學者使用wireshark時,將會得到大量的冗余數據包列表,以至于很難找到自己需要抓取的數據包部分。

wireshark工具中自帶了兩種類型的過濾器,學會使用這兩種過濾器會幫助我們在大量的數據中迅速找到我們需要的信息。

1.抓包過濾器

捕獲過濾器的菜單欄路徑為 捕獲 --> 捕獲過濾器。用于在抓取數據包前設置。

如何使用呢?設置如下。

 ip host 183.232.231.172表示只捕獲主機IP為183.232.231.172的數據包。獲取結果如下:

2. 顯示過濾器

顯示過濾器是用于在抓取數據包后設置過濾條件進行過濾數據包。

通常是在抓取數據包時設置條件相對寬泛或者沒有設置導致抓取的數據包內容較多時使用顯示過濾器設置條件過濾以方便分析。

 執行ping www.baidu.com獲取的數據包列表如下

 觀察上述獲取的數據包列表,含有大量的無效數據。這時可以通過設置顯示器過濾條件進行提取分析信息。ip.addr == 183.232.231.172,并進行過濾。

上述介紹了抓包過濾器和顯示過濾器的基本使用方法。在組網不復雜或者流量不大情況下,使用顯示器過濾器進行抓包后處理就可以滿足我們使用。下面介紹一下兩者間的語法以及它們的區別。

八、wireshark過濾器表達式的規則

1. 抓包過濾器語法和實例

抓包過濾器類型Type(host、net、port)、方向Dir(src、dst)、協議Proto(ether、ip、tcp、udp、http、icmp、ftp等)、邏輯運算符(&&與、|| 或、!非)

(1)協議過濾

比較簡單,直接在抓包過濾框中直接輸入協議名即可。

tcp,只顯示TCP協議的數據包列表

http,只查看HTTP協議的數據包列表

icmp,只顯示ICMP協議的數據包列表

(2)IP過濾

host 192.168.1.104

src host 192.168.1.104

dst host 192.168.1.104

(3)端口過濾

port 80

src port 80

dst port 80

(4)邏輯運算符&&與、|| 或、!非

src host 192.168.1.104 &&dst port 80 抓取主機地址為192.168.1.80、目的端口為80的數據包

host 192.168.1.104 || host 192.168.1.102 抓取主機為192.168.1.104或者192.168.1.102的數據包

!broadcast 不抓取廣播數據包

2. 顯示過濾器語法和實例

(1)比較操作符

比較操作符有

== 等于、!= 不等于、> 大于、< 小于、>= 大于等于、<=小于等于

(2)協議過濾

比較簡單,直接在Filter框中直接輸入協議名即可。注意:協議名稱需要輸入小寫。

tcp,只顯示TCP協議的數據包列表

http,只查看HTTP協議的數據包列表

icmp,只顯示ICMP協議的數據包列表

(3) ip過濾

ip.src ==112.53.42.42 顯示源地址為112.53.42.42的數據包列表

ip.dst==112.53.42.42, 顯示目標地址為112.53.42.42的數據包列表

ip.addr == 112.53.42.42 顯示源IP地址或目標IP地址為112.53.42.42的數據包列表

(4)端口過濾

tcp.port ==80,  顯示源主機或者目的主機端口為80的數據包列表。

tcp.srcport == 80,  只顯示TCP協議的源主機端口為80的數據包列表。

tcp.dstport == 80,只顯示TCP協議的目的主機端口為80的數據包列表。

5) http模式過濾

http.request.method=="GET",   只顯示HTTP GET方法的。

(6)邏輯運算符為 and/or/not

過濾多個條件組合時,使用and/or。比如獲取IP地址為192.168.0.104的ICMP數據包表達式為ip.addr == 192.168.0.104 and icmp

(7)按照數據包內容過濾

假設我要以ICMP層中的內容進行過濾,可以單擊選中界面中的碼流,在下方進行選中數據。

 右鍵單擊選中后出現如下界面

 選中后在過濾器中顯示如下

 后面條件表達式就需要自己填寫。如下我想過濾出data數據包中包含"abcd"內容的數據流。關鍵詞是contains,完整條件表達式為data contains "abcd"

看到這, 基本上對wireshak有了初步了解。

3. 常見用顯示過濾需求及其對應表達式

數據鏈路層:

篩選mac地址為04:f9:38:ad:13:26的數據包

eth.src == 04:f9:38:ad:13:26

篩選源mac地址為04:f9:38:ad:13:26的數據包----

eth.src == 04:f9:38:ad:13:26

網絡層:

篩選ip地址為192.168.1.1的數據包

ip.addr == 192.168.1.1

篩選192.168.1.0網段的數據

ip contains "192.168.1"

傳輸層:

篩選端口為80的數據包

tcp.port == 80

篩選12345端口和80端口之間的數據包

tcp.port == 12345 &&tcp.port == 80

篩選從12345端口到80端口的數據包

tcp.srcport == 12345 &&tcp.dstport == 80

應用層:

特別說明: http中http.request表示請求頭中的第一行(如GET index.jsp HTTP/1.1) http.response表示響應頭中的第一行(如HTTP/1.1 200 OK),其他頭部都用http.header_name形式。

篩選url中包含.php的http數據包

http.request.uri contains ".php"

篩選內容包含username的http數據包

http contains "username"

九、Wireshark抓包分析TCP三次握手

1. TCP三次握手連接建立過程

Step1:客戶端發送一個SYN=1,ACK=0標志的數據包給服務端,請求進行連接,這是第一次握手;

Step2:服務端收到請求并且允許連接的話,就會發送一個SYN=1,ACK=1標志的數據包給發送端,告訴它,可以通訊了,并且讓客戶端發送一個確認數據包,這是第二次握手;

Step3:服務端發送一個SYN=0,ACK=1的數據包給客戶端端,告訴它連接已被確認,這就是第三次握手。TCP連接建立,開始通訊。

 

2. Wireshark抓包獲取訪問指定服務端數據包

Step1:啟動wireshark抓包,打開瀏覽器輸入www.baidu.com。

Step2:使用ping www.baidu.com獲取IP。

Step3:輸入過濾條件獲取待分析數據包列表 ip.addr == 183.232.231.172

圖中可以看到wireshark截獲到了三次握手的三個數據包。第四個包才是HTTPS的, 這說明HTTPS的確是使用TCP建立連接的。

第一次握手數據包

客戶端發送一個TCP,標志位為SYN,序列號為0, 代表客戶端請求建立連接。

數據包的關鍵屬性如下:

SYN :標志位,表示請求建立連接

Seq = 0 :初始建立連接值為0,數據包的相對序列號從0開始,表示當前還沒有發送數據

Ack =0:初始建立連接值為0,已經收到包的數量,表示當前沒有接收到數據

第二次握手的數據包

服務器發回確認包, 標志位為 SYN,ACK。將確認序號(Acknowledgement Number)字段+1,即0+1=1。

數據包的關鍵屬性如下:

[SYN + ACK]: 標志位,同意建立連接,并回送SYN+ACK

Seq = 0 :初始建立值為0,表示當前還沒有發送數據

Ack = 1:表示當前端成功接收的數據位數,雖然客戶端沒有發送任何有效數據,確認號還是被加1,因為包含SYN或FIN標志位。(并不會對有效數據的計數產生影響,因為含有SYN或FIN標志位的包并不攜帶有效數據)

第三次握手的數據包

客戶端再次發送確認包(ACK) SYN標志位為0,ACK標志位為1。并且把服務器發來ACK的序號字段+1,放在確定字段中發送給對方,并且在Flag段寫ACK的+1:

數據包的關鍵屬性如下:

ACK :標志位,表示已經收到記錄

Seq = 1 :表示當前已經發送1個數據

Ack = 1 : 表示當前端成功接收的數據位數,雖然服務端沒有發送任何有效數據,確認號還是被加1,因為包含SYN或FIN標志位(并不會對有效數據的計數產生影響,因為含有SYN或FIN標志位的包并不攜帶有效數據)。

就這樣通過了TCP三次握手,建立了連接。開始進行數據交互

十、Wireshark分析常用操作

調整數據包列表中時間戳顯示格式。調整方法為 視圖 -->時間顯示格式 --> 日期和時間。調整后格式如下:

 

一般Wireshark軟件也可以與各主流廠家的模擬器一起使用,更適合于項目準確配置。


該文章在 2024/10/12 15:51:28 編輯過
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产精品91一区二区三区四区 | 天堂在线8一区二区三区 | 精品欧美视频第二页在线观看 | 国产中文成人精品久v | 99好久| 亚洲国产中文字幕在线观看 | 国产精品视频免费看人鲁 | 96精品专区国产在线观看高清 | 国亚洲一厂区二厂区三厂区 | 在线欧美日韩国产 | 国产精品免费高清在线观看 | 99精品国产丝袜在线拍国语 | 日韩欧美一区二区三区在线观看 | 91国产最 | 性xxxxx欧美 成人妇女免费 | 国产乱码高清区二区三区在线 | 在线播放不收费 | 91成人深夜在线观看 | 亚洲欧美国产日产综合不卡 | 97国产婷婷综合视 | 亚洲狠狠 | 91蜜芽尤物福利在线观看 | 国产人成视频 | 国产男女免费完整视频网页 | 天堂va蜜桃一区二区三区 | 亚洲精品日韩三区 | 国产中文字幕在线免费观看 | 国产情侣套| 男子操性感黑丝美女视频 | 在线欧美日韩成人 | 成人激情电影 | 国产精品午夜看片 | 精品日本一区 | 91香蕉国产观看免费人人 | 成人欧美一区二区三区黑人 | 日本喷奶水中文字幕视频 | 亚洲精品国产一级高清在线观看 | 永久在线观看 | 欧美日韩国产一区二区三区欧 | 国产激情在线观看 | 99在线精品日韩一区免费国产 |