您的位置:首页 > 理论基础 > 计算机网络

tcpdump介绍

2016-07-01 15:13 369 查看
以前记得一篇笔记,贴出了
tcpdump介绍

用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具。 tcpdump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。

帮助文档:
man tcpdump
man pcap-filter

tcpdump常用的参数如下:
-i # 指定监听的网络接口。

-n# 将地址显示为数字格式
-nn# 将地址、端口显示为数字格式
-c# 在收到指定的数量的分组后,tcpdump就会停止。
-F# 从指定的文件中读取表达式,忽略命令行中给出的表达式。
-N# 不输出主机名中的域名部分。例如,‘nic.ddn.mil‘只输出’nic‘。
-P# 不将网络接口设置成混杂模式
-q# 快速输出。只输出较少的协议信息。
-X# 分别以16进制和ASCII码格式显示
-XX# 显示链路层首部信息
-A# 以ASCII码格式显示
-T# 将监听到的包直接解释为指定的类型的报文,常见的类型有rpc远程过程调用)和snmp (简单网络管理协议;)。
-v# 输出一个稍微详细的信息,例如在ip包中可以包括ttl和服务类型的信息。
-vv# 输出详细的报文信息。
-w# 直接将分组写入文件中,而不是不分析并打印出来。
-r# 读取抓包的文件并分析

tcpdump的表达式介绍
表达式是一个正则表达式,tcpdump利用它作为过滤报文的条件,如果一个报文满足表 达式的条件,则这个报文将会被捕获。如果没有给出任何条件,则网络上所有的信息包 将会被截获。

第一种是关于类型的关键字,主要包括host,net,port,例如 host 210.27.48.2, 指明 210.27.48.2是一台主机,net 202.0.0.0指明202.0.0.0是一个网络地址,port 23 指明端口号是23。如果没有指定类型,缺省的类型是host。

第二种是确定传输方向的关键字,主要包括src,dst,dst or src,dst and src, 这些关键字指明了传输的方向。举例说明,src 210.27.48.2 ,指明ip包中源地址是 210.27.48.2 , dst net 202.0.0.0 指明目的网络地址是202.0.0.0。如果没有指明 方向关键字,则缺省是src or dst关键字。

第三种是协议的关键字,主要包括fddi,ip,arp,rarp,tcp,udp等类型。Fddi指明是在FDDI (分布式光纤数据接口网络) 上的特定的网络协议,实际上它是”ether”的别名,fddi和ether 具有类似的源地址和目的地址,所以可以将fddi协议包当作ether的包进行处理和分析。 其他的几个关键字就是指明了监听的包的协议内容。如果没有指定任何协议,则tcpdump 将会 监听所有协议的信息包。

除了这三种类型的关键字之外,其他重要的关键字如下:gateway, broadcast,less, greater, 还有三种逻辑运算,取非运算是 ‘not ‘ ‘! ‘, 与运算是’and’,’&&’;或运算是’or’ ,’||’; 这些关键字可以组合起来构成强大的组合条件来满足人们的需要。

常用表达式
非 : ! or "not" (去掉双引号)
且 : && or "and"
或 : || or "or"

例子
tcpdump -i eth0 -nn src host x.x.x.x and tcp dst port 80# 抓取x.x.x.x到本机80端口的TCP通信

# 抓取所有经过eth1,目的或源端口是25的网络数据
tcpdump -i eth1 port 25

# 指定[源|目的]端口
tcpdump -i eth1 [src|dst] port 25

# 网络过滤类
tcpdump -i eth1 net 192.168
tcpdump -i eth1 src net 192.168
tcpdump -i eth1 dst net 192.168

# 协议过滤类
tcpdump -i eth1 arp
tcpdump -i eth1 ip
tcpdump -i eth1 tcp
tcpdump -i eth1 udp
tcpdump -i eth1 icmp
tcpdump -i eth0 -nn host 172.16.20.62 and host 172.16.0.1

# 抓取所有经过eth1,目的地址是192.168.1.254或192.168.1.200端口是80的TCP数据
tcpdump -i eth1 ' ( (tcp)  and  (port 80)  and  ( (dst host 192.168.1.254)  or  (dst host 192.168.1.200) ) ) '

# 抓取所有经过eth1,目标MAC地址是00:01:02:03:04:05的ICMP数据
tcpdump -i eth1 ' ( (icmp)  and  ( (ether dst host 00:01:02:03:04:05) ) ) '

# 抓取所有经过eth1,目的网络是192.168,但目的主机不是192.168.1.200的TCP数据
tcpdump -i eth1 ' ( (tcp)  and  ( (dst net 192.168)  and  (not dst host 192.168.1.200) ) ) '

# 抓取172.16.20.62与172.16.0.1或者172.16.20.62与172.16.20.72之间的通信
tcpdump -i eth0 -nn host 172.16.20.62 and \ (172.16.0.1 or 172.16.20.72\)

# 使用tcpdump抓取访问eth0适配卡且访问端口为tcp 9080?
tcpdump -i eth0 dst 172.168.70.35 and tcp port 9080

# 监听来自eth0适配卡且通信协议为port 22,目标来源为192.168.1.100的数据包资料?
tcpdump -i eth0 -nn port 22 and src host 192.168.1.100

(1)  想要截获所有210.27.48.1 的主机收到的和发出的所有的分组:
#tcpdump host 210.27.48.1

(2)  想要截获主机210.27.48.1 和主机210.27.48.2或210.27.48.3的通信,使用命令 (注意:括号前的反斜杠是必须的):
#tcpdump host 210.27.48.1 and \ (210.27.48.2 or 210.27.48.3 \)

(3)  如果想要获取主机210.27.48.1除了和主机210.27.48.2之外所有主机通信的ip包,使用命令:
#tcpdump ip host 210.27.48.1 and ! 210.27.48.2

(4)  如果想要获取主机192.168.228.246接收或发出的ssh包,并且不转换主机名使用如下命令:
#tcpdump -nn -n src host 192.168.228.246 and port 22 and tcp

(5)  获取主机192.168.228.246接收或发出的ssh包,并把mac地址也一同显示:
# tcpdump -e src host 192.168.228.246 and port 22 and tcp -n -nn

(6)  过滤的是源主机为192.168.0.1与目的网络为192.168.0.0的报头:
tcpdump src host 192.168.0.1 and dst net 192.168.0.0/24

(7)  过滤源主机物理地址为XXX的报头:
tcpdump ether src 00:50:04:BA:9B and dst……
(为什么ether src后面没有host或者net?物理地址当然不可能有网络喽)。

(8)  过滤源主机192.168.0.1和目的端口不是telnet的报头,并导入到tes.t.txt文件中:
Tcpdump src host 192.168.0.1 and dst port not telnet -l > test.txt

(9)  抓取与主机192.168.43.23或着与主机192.168.43.24通信报文,并且显示在控制台上
tcpdump -X -s 1024 -i eth0 host \ (192.168.43.23 or 192.168.43.24\)  and  host 172.16.70.35


网上补充的教程: http://linuxwiki.github.io/NetTools/tcpdump.html#28 http://www.cnblogs.com/ggjucheng/archive/2012/01/14/2322659.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: