轉自:http://www.cnblogs.com/TankXiao/archive/2012/10/10/2711777.htmlhtml
以前寫過一篇博客:用 Fiddler 來調試HTTP,HTTPS。編程
這篇文章介紹還有一個好用的抓包工具wireshark。 用來獲取網絡數據封包。包含http,TCP,UDP,等網絡協議包。windows
記得大學的時候就學習過TCP的三次握手協議,那時候僅僅是知道,儘管在書上看過很是多TCP和UDP的資料,但是歷來沒有真正見過這些數據包, 總是感受在雲上飄同樣,學得不踏實。有了wireshark就能截獲這些網絡數據包,可以清晰的看到數據包中的每一個字段。更能加深咱們對網絡協議的理解。瀏覽器
對我而言。 wireshark 是學習網絡協議最好的工具。安全
閱讀文件夾
網絡
wireshark的官方下載站點: http://www.wireshark.org/socket
wireshark是很流行的網絡封包分析軟件,功能十分強大。tcp
可以截取各類網絡封包,顯示網絡封包的具體信息。工具
wireshark是開源軟件,可以放心使用。 可以執行在Windows和Mac OS上。學習
使用wireshark的人必須瞭解網絡協議。不然就看不懂wireshark了。
爲了安全考慮,wireshark僅僅能查看封包。而不能改動封包的內容,或者發送封包。
Fiddler是在windows上執行的程序,專門用來捕獲HTTP,HTTPS的。
wireshark能獲取HTTP,也能獲取HTTPS,但是不能解密HTTPS,因此wireshark看不懂HTTPS中的內容
總結。假設是處理HTTP,HTTPS 仍是用Fiddler, 其它協議比方TCP,UDP 就用wireshark
微軟的network monitor
sniffer
1. 網絡管理員會使用wireshark來檢查網絡問題
2. 軟件測試project師使用wireshark抓包,來分析本身測試的軟件
3. 從事socket編程的project師會用wireshark來調試
4. 據說。華爲,中興的大部分project師都會用到wireshark。
總之跟網絡相關的東西。均可能會用到wireshark.
開始界面
wireshark是捕獲機器上的某一塊網卡的網絡包,當你的機器上有多塊網卡的時候。你需要選擇一個網卡。
點擊Caputre->Interfaces.. 出現如下對話框,選擇正確的網卡。
而後點擊"Start"button, 開始抓包
WireShark 主要分爲這幾個界面
1. Display Filter(顯示過濾器), 用於過濾
2. Packet List Pane(封包列表), 顯示捕獲到的封包, 有源地址和目標地址,port號。
顏色不一樣。表明
3. Packet Details Pane(封包具體信息), 顯示封包中的字段
4. Dissector Pane(16進制數據)
5. Miscellanous(地址欄。雜項)
使用過濾是很是重要的, 剛開始學習的人使用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 |
封包列表的面板中顯示,編號。時間戳,源地址,目標地址,協議,長度。以及封包信息。 你可以看到不一樣的協議用了不一樣的顏色顯示。
你也可以改動這些顯示顏色的規則, View ->Coloring Rules.
這個面板是咱們最重要的。用來查看協議中的每一個字段。
各行信息分別爲
Frame: 物理層的數據幀概況
Ethernet II: 數據鏈路層以太網幀頭部信息
Internet Protocol Version 4: 互聯網層IP包頭部信息
Transmission Control Protocol: 傳輸層T的數據段頭部信息,此處是TCP
Hypertext Transfer Protocol: 應用層的信息,此處是HTTP協議
從下圖可以看到wireshark捕獲到的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三次握手,創建了鏈接