利器:网络抓包工具——tcpdump

简介

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

使用帮助

yum install -y tcpdump

帮助文档

[root@test ~]# tcpdump --help
tcpdump version 4.9.0
libpcap version 1.5.3
OpenSSL 1.0.1e-fips 11 Feb 2013
Usage: tcpdump [-aAbdDefhHIJKlLnNOpqStuUvxX#] [ -B size ] [ -c count ]
		[ -C file_size ] [ -E algo:secret ] [ -F file ] [ -G seconds ]
		[ -i interface ] [ -j tstamptype ] [ -M secret ] [ --number ]
		[ -Q|-P in|out|inout ]
		[ -r file ] [ -s snaplen ] [ --time-stamp-precision precision ]
		[ --immediate-mode ] [ -T type ] [ --version ] [ -V file ]
		[ -w file ] [ -W filecount ] [ -y datalinktype ] [ -z postrotate-command ]
		[ -Z user ] [ expression ]

[root@test ~]# man tcpdump
[root@test ~]# man pcap-filter

常用选项

-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 / ||; 这些关键字可以组合起来构成强大的组合条件来满足人们的需要。

  • 非 : ! == not
  • 且 : && == and
  • 或 : || == or

转自:

  1. http://www.ha97.com/4550.html
  2. http://linuxwiki.github.io/NetTools/tcpdump.html
posted @ 2018-05-27 10:39  M1927  阅读(41)  评论(0)    收藏  举报