利器:网络抓包工具——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

浙公网安备 33010602011771号