開始之前先推薦一個wireshark視頻:
http://www.shiyanbar.com/course-video/watchVideo/cid/419/vid/2001
頁面功能簡介
1.主界面中,波動的線代表網卡傳輸信息的波動,以實際網卡為準。如圖:
網絡抓包工具wireshark,2.捕捉機器上某一塊網卡的網絡數據包,當你的機器上有多塊網卡的時候,你需要選擇一個網卡。
點擊Caputre->Interfaces.. 出現下面對話框,選擇正確的網卡。然后點擊"Start"按鈕, 開始抓包
?
3.wireshark捕捉窗口介紹
解卡什么意思,?
?
WireShark 主要分為這幾個界面:
1. Display Filter(顯示過濾器),? 用于過濾
2. Packet List Pane(封包列表), 顯示捕獲到的封包, 有源地址和目標地址,端口號。 顏色不同,代表
知 解。3. Packet Details Pane(封包詳細信息), 顯示封包中的字段
4. Dissector Pane(16進制數據)
5. Miscellanous(地址欄,雜項)
?
解的用法?使用過濾是非常重要的, 初學者使用wireshark時,將會得到大量的冗余信息,在幾千甚至幾萬條記錄中,以至于很難找到自己需要的部分。搞得暈頭轉向。
過濾器會幫助我們在大量的數據中迅速找到我們需要的信息。
過濾器有兩種,
一種是顯示過濾器,就是主界面上那個,用來在捕獲的記錄中找到所需要的記錄
一種是捕獲過濾器,用來過濾捕獲的封包,以免捕獲太多的記錄。 在Capture -> Capture Filters 中設置
wireshark ping抓包,保存過濾
在Filter欄上,填好Filter的表達式后,點擊Save按鈕, 取個名字。比如"Filter 102",
Filter欄上就多了個"Filter 102" 的按鈕。
?
wireshark使用。過濾表達式的規則:
表達式規則
1. 協議過濾
比如TCP,只顯示TCP協議。
2. IP 過濾
wireshark抓包實例,比如 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的。
wireshark使用教程入門,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 |
? | ? |
? | ? |
?
?
?
?
怎樣用wireshark抓包,封包列表(Packet List Pane)
封包列表的面板中顯示,編號,時間戳,源地址,目標地址,協議,長度,以及封包信息。 你可以看到不同的協議用了不同的顏色顯示。
你也可以修改這些顯示顏色的規則,? View ->Coloring Rules.
?
封包詳細信息 (Packet Details Pane)
wireshark 教程,這個面板是我們最重要的,用來查看協議中的每一個字段。
各行信息分別為
Frame:???物理層的數據幀概況
Ethernet?II:?數據鏈路層以太網幀頭部信息
Internet Protocol Version 4:?互聯網層IP包頭部信息
Transmission Control Protocol:??傳輸層T的數據段頭部信息,此處是TCP
Hypertext Transfer Protocol:??應用層的信息,此處是HTTP協議
TCP包的具體內容
?從下圖可以看到wireshark捕獲到的TCP包中的每個字段。
看到這, 基本上對wireshak有了初步了解, 現在我們看一個TCP三次握手的實例
?三次握手過程為
這圖我都看過很多遍了, 這次我們用wireshark實際分析下三次握手的過程。
打開wireshark, 打開瀏覽器輸入?http://www.cr173.com
在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三次握手,建立了連接
?
?
?
?
?另附數據包分析基礎:
四:抓包數據分析
?
這是我抓取的一段HTTP建聯過程(三次握手)
以某一段數據包分析(這里是以第三個包分析),大概了解一下!!!
?
附圖:TCP報文格式(詳細了解點擊:http://blog.csdn.net/u011244446/article/details/47176025)
?
注意:右擊鼠標---->Follow TCP Stream 顯示服務器和目標之間的全部的對話??? 如下
?
HTTP數據包分析
HTTP分為請求報文、響應報文
請求報文分析:
響應報文分析:
?
附圖:HTTP請求報文AND響應報文(詳情點擊:http://www.admin10000.com/document/5885.html)
?
?
五:Wireshare數據包過濾
?
點擊---->Filter,創建新的過濾條件
具體的過濾語法書寫點擊:
http://blog.csdn.net/hishentan/article/details/12850563
http://blog.163.com/lan_ne/blog/static/1926701702014429767884/
?