以前记得一篇笔记,贴出了
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