国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Linux > 正文

Linux tcpdump命令的用法詳細解析

2020-10-28 18:49:32
字體:
來源:轉載
供稿:網友

英文原意是dump traffic on a network ,即截獲網絡上的數據報,可以根據指定的網絡接口來截獲不同的數據報。它會輸出在某個網絡接口上符合匹配表達式的報內容的描述。當tcpdump完成抓包后,會打印出類似下面的內容: 

9 packets captured
56 packets received by filter
17 packets dropped by kernel

當然,在讀取網絡上的數據包時,得需要特權,比如linux上的超級用戶

tcpdump用法

tcpdump -A 用ascii打印出每個包信息,這個對于截獲網頁很方便
tcpdump -D 打印出當前系統的可用的網絡接口。可以用-i選項來指定特定的接口


tcpdump -F 使用文件作為輸入的過濾表達式

tcpdump -i 在指定的接口上進行監聽。如果未指定,tcpdump會從interface list 中尋找最低數字作為監聽的接口

tcpdump -l  使標準輸出成為緩沖區,如果你想在截獲數據包的同時也查看數據,則可以使用下面命令
tcpdump -l > dat & tail -f dat
tcpdump -S 打印出TCP絕對的序列號
tcpdump -w 將截獲的數據包寫到一個文件中
如果沒有表達式,則網絡上所有的包都會被截獲

例子TCP Packets

下面就是TCP 報文的格式

src > dst : flags data-segno ack window  urgent options(MSS, 時間戳,窗口規模選項)
1. 要截獲特定標志位的TCP 包:在TCP header中,有8位是控制位

CWR | ECE | URG | ACK | PSH | RST | SYN | FIN

有TCP 頭的結構中

       0                            15                                     31
       -------------------------------------------------------------------------
       |          source port          |       destination port      |
       -------------------------------------------------------------------------
       |                        sequence number                       |
       -------------------------------------------------------------------------
       |                     acknowledgment number                |

       --------------------------------------------------------------------------
       |  HL   | rsvd  |C|E|U|A|P|R|S|F|        window size   |
       --------------------------------------------------------------------------
       |         TCP checksum          |       urgent pointer    |
       --------------------------------------------------------------------------

8為控制位是TCP頭中的第13個 8-bits組

                       |                        |
                       |------------------------|
                       |C|E|U|A|P|R|S|F|
                       |------------------------|
                       |7     5    3        0|

當SYN位為1時

則該8-bits組的二進制表示為:00000010  -> 2
所以只截獲TCP中標志位為SYN=1的表達式為
tcpdump -i 2 tcp[13]==2  
tcp[13]==2  就是讓TCP數據報中的第13個8bits組的值為2


2. 如果TCP報文中帶有SYN-ACK,我們認為他是帶SYN的報文,那么該咋截獲呢

                       |                        |
                       |------------------------|
                       |C|E|U|A|P|R|S|F|
                       |------------------------|
                       |7     5    3        0|

此時該8bits組的二進制表示為 00010010 ->18

此時應該不是 tcp[13] == 18,這樣只能截獲ACK-SYN報文,而不能再截獲SYN報文啦,這時我們應該要維持SYN所在位的值,可以用上邏輯與運算,即如下

‘tcp[13] & 2 == 2' ,就可以啦

注意:下面截圖的TCP報文的第二條的標志位 [S.]



UDP Packets

UDP 報文的格式為

  actibude.who > broadcast.who : udp 84

who 為端口號,artinide,broadcast都是主機的網絡地址, 84為UDP數據報的大小

UDP name Server Requests

請求報文的格式為

src > dst : id op? flags qtype qclass name(len)

h2opolo.1538 > helios.domain : 3+ A? ucbvax.berkeley.edu (37)

主機hopolo詢問主機helios上的domain服務的地址記錄(qtype=A),該機路與ucbvax.berkeley,edu相關聯

查詢id為3,‘+'表明 recursion-desired flag 被設置,query的長度為37字節,沒有包括UDP與IP的頭長度

UDP Name Server Responses
src > dst : id op rcode flags a/n/au type class data(len)
 helios.domain > h2opolo.1538 : 3 3/3/7 A 128.32.137.3 (273)

該報文是helios響應來自h2opolo的query id 為3,且帶有3個answer record,3 個name server records 和 7 個additional records

第一個 answer record 是type A ,它數據的大小為273字節,包括UDP和IP報文頭

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚东县| 丰镇市| 新龙县| 区。| 临泉县| 手游| 武冈市| 乌苏市| 刚察县| 剑河县| 中阳县| 准格尔旗| 尼木县| 石台县| 蒲江县| 青川县| 东兰县| 中西区| 大英县| 美姑县| 柳州市| 宁阳县| 诸暨市| 甘孜| 柳州市| 龙江县| 霍林郭勒市| 应用必备| 重庆市| 清丰县| 嘉黎县| 潼南县| 河间市| 突泉县| 梁河县| 泾川县| 光山县| 怀来县| 龙门县| 翁牛特旗| 云梦县|