以前记得一篇笔记,贴出了

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