tcpdump参数及使用介绍(转)

原文地址:http://dogdogcom.blog.51cto.com/2402458/490398

tcpdump

   -a    将网络地址和广播地址转变成名字;

   -d    将匹配信息包的代码以人们可以理解的汇编格式给出;

   -dd     将匹配信息包的代码以c语言程序段的格式给出;

   -ddd   将匹配信息包的代码以十进制的形式给出;

   -e    在输出行打印出数据链路层的头部信息;

   -f     将外部的Internet地址以数字的形式打印出来。

   -l     使标准输出变为缓冲行形式;

   -n    不把网络地址转换成名字;

   -t     在输出的每一行不打印时间戳;

   -v    输出一个略微具体的信息。比如在ip包中能够包含ttl和服务类型的信息;

   -vv     输出具体的报文信息;

   -c    在收到指定的包的数目后。tcpdump就会停止;

   -F      从指定的文件里读取表达式,忽略其他的表达式;

   -i     指定监听的网络接口。

   -r    从指定的文件里读取包(这些包一般通过-w选项产生);

   -w     直接将包写入文件里,并不分析和打印出来;

   -T     将监听到的包直接解释为指定的类型的报文,常见的类型有rpc(远程过程调用)和snmp(简单网络管理协议)

-p           指定协议tcp,udp,icmp,arp

-s           指定捕获数包字的大小,单位byte,默认96最大65536

可使用keyword:

协议,-p tcp,udp,icmp,arp等

数据包:dst,src,port,dst port,src port,host

运算符:or and not(!)

多条件:dst \(172.16.1.1 or 172.16.1.13 \) 用括号及\转义

在进行嗅探的时候,必须置于混杂模式才干嗅探,系统会有日志记录

grep "promiscuous" /var/log/messages //混杂模式

用TCPDUMP捕获的TCP包的一般输出信息是:

  src.port > dst.port: flags data-Seq ack win urgent options

  src.port > dst.port: 源地址.源端口 到 目的地址.目的端口

flags:                 TCP包中的标志信息,S 是SYN标志, F (FIN), P (PUSH)

R (RST) "." (没有标记)

data-Seq:      是数据包中Sequence number(顺序号码)

ack:              Acknowledge number(确认号码)

window是接收缓存的窗体大小,

urgent表明数据包中是否有紧急指针.

注tcp标志位:

SYN(synchronous建立联机) ACK(acknowledgement 确认)

PSH(push传送) FIN(finish结束) RST(reset重置) URG(urgent紧急)

查看icmp包:

1,tcpdump -i eth0 -p icmp    (and src 192.168.1.xxx)

查看广播包:

2,tcpdump -i eth0 -p broadcast

查看arp包

3,tcpdump -i eth0 -p arp

4,tcpdump -X -i eth0 -p tcp port 21 //嗅探21端口数据并解包

获取ftppassword实例:

tcpdump -X -i eth0 -p tcp port 21 > 21.log &

cat 21.log | grep "USER\."

cat 21.log | grep "PASS\."

更精确的嗅探:

嗅探从172.16.1.1到172.16.1.2port为21的数据包:

tcpdump -i eth0 -X -tnn -p tcp and src 172.16.1.1 and dst 172.16.1.2 and port 21

5.tcpdump -X -n -p tcp dst port 80 //嗅探80端口数据,并解包 (加-t就不显示时间)

6.tcpdump -i eth0 host 202.96.128.68 //指定主机

7,//嗅探从172.16.1.2到172.16.1.1 或者172.16.1.13的数据包

tcpdump -i eth0 -tnn src 172.16.1.2 and dst \(172.16.1.1 or 172.16.1.13 \)

8,利用tcpdump统计各类数据包:

//统计1000个数据包中的ip连接量,并按从多到少的顺序排序,列出前3名

tcpdump -i ethp -tnn -c 1000 | awk -F "." "{print $1"."$2"."$3"."$4}‘ | sort | uniq -c |sort -nr | head -n 3//按从大到小的顺

序排序并列出并三名

tcpdump -i ethp -tnn -c 1000 | awk -F "." "{print $1"."$2"."$3"."$4}‘ | sort | uniq -c | awk ‘$1 > 100‘//显示大于100数据包

sort:排序 -nr 从大到小 -rn 从小到大

uniq -c:过滤反复并在前面打印反复的行数

awk ‘$1 > 100‘:假设$1參数(数字)大于100

head -n 3:显示头3行

9,tcpdump -i eth0 -tnn host 192.168.1.100 and -p tcp or udp or icmp    //嗅探全部 tcp,udp,icmp消息所不转换网络名称(加高速度)

10,嗅探dhcpserver的ip(捕获非法DHCP Server):

tcpdump -i eth0 -tnn port 67

然后dhclient eth0进行dhcp请求,抓住dhcp server的ip地址

或者看看直接登录它cat /var/messages | grep "DHCPACK from"

时间: 2024-10-02 04:28:34

tcpdump参数及使用介绍(转)的相关文章

tcpdump参数解析及使用详解

tcpdump介绍 tcpdump 是一个运行在命令行下的抓包工具.它允许用户拦截和显示发送或收到过网络连接到该计算机的TCP/IP和其他数据包.tcpdump 适用于 大多数的类Unix系统操作系统(如linux,BSD等).类Unix系统的 tcpdump 需要使用libpcap这个捕捉数据的库就像 windows下的WinPcap. 在学习tcpdump前最好对基本网络的网络知识有一定的认识. tcpdump命令格式及常用参数 Tcpdump的大概形式如下: 例:tcpdump –i et

(转) tcpdump参数解析及使用详解

tcpdump介绍 原文:http://blog.csdn.net/hzhsan/article/details/43445787 tcpdump 是一个运行在命令行下的抓包工具.它允许用户拦截和显示发送或收到过网络连接到该计算机的TCP/IP和其他数据包.tcpdump 适用于 大多数的类Unix系统操作系统(如linux,BSD等).类Unix系统的 tcpdump 需要使用libpcap这个捕捉数据的库就像 windows下的WinPcap. 在学习tcpdump前最好对基本网络的网络知识

Inf2Cat应用的参数使用详细介绍

http://msdn.microsoft.com/zh-cn/subscriptions/ff547089 ? Inf2Cat Inf2Cat (Inf2Cat.exe) 是一个命令行工具,该工具确定驱动程序包的?INF 文件是否可以针对指定的 Windows 版本列表进行数字签名.如果可以,那么 Inf2Cat 会生成适用于指定 Windows 版本的未签名的目录文件. Inf2Cat /driver: PackagePath /os: WindowsVersionList [/nocat]

STM32 一种参数检查用法介绍

STM32 一种参数检查用法介绍 assert_param()是一个在代码中很常见的写法,这个函数的功能一般是对函数参数的合法性进行检查,这里以一个例子进行分析: assert_param(IS_GPIO_ALL_PERIPH(GPIOx)) 函数的参数是IS_GPIO_ALL_PERIPH(GPIOx),原型为: #define IS_GPIO_ALL_PERIPH(PERIPH) (((PERIPH) == GPIOA) || ((PERIPH) == GPIOB) || ((PERIPH)

ORACLE推导参数Derived Parameter介绍

Oracle的推导参数(Derived Parameters)其实是初始化参数的一种.推导参数值通常来自于其它参数的运算,依赖其它参数计算得出.官方文档关于推导参数(Derived Parameters)的概念如下: Derived Parameters Some initialization parameters are derived, meaning that their values are calculated from the values of other parameters.

Linux Rsync参数及命令介绍

一.Rsync介绍 Rsync(Remote Synchronize) 是一个远程资料同步工具,可通过LAN/WAN快速同步多台主机,Rsync使用所为的"Rsync演算法"来使本地主机和远程主机之间达到同步,这个演算法并不是每次都整份传送,它只传送两台计算机之间所备份的资料不同的部分,因此速度相当快. Rsync的优点如下: l  支持拷贝特殊文件如链接文件,设备等 l  可以有排除指定文件或目录同步的功能,相当于打包命令tar的排除功能 l  可以做到保持源文件或目录的权限.时间.

【转】C/C++中可变参数的详细介绍(va_list,va_start,va_arg,va_end)

可变参数的函数原理其实很简单,而va系列是以宏定义来定义的,实现跟堆栈相关.我们写一个可变函数的C函数时,有利也有弊,所以在不必要的场合,我们无需用到可变参数.如果在C++里,我们应该利用C++的多态性来实现可变参数的功能,尽量避免用C语言的方式来实现. 由于在C语言中没有函数重载,解决不定数目函数参数问题变得比较麻烦,即使采用C++,如果参数个数不能确定,也很难采用函数重载.对这种情况,提出了指针参数来解决问题. 如printf()函数,其原型为:int   printf(   const  

LR中变量、参数的使用介绍

Action(){ char * url = "www.baidu.com"; char arr_url[1024]; //将url变量的值复制给p_url1参数 lr_save_string(url,"p_url"); //将p_url1参数的值复制给arr_url变量 strcpy(arr_url,"URL=http://"); strcat(arr_url,lr_eval_string("{p_url}")); lr_o

LR脚本示例之参数_变量介绍

Action(){ char *url = "127.0.0.1:1080"; char arr_url[1024]; //将url变量的值复制给p_url1参数 lr_save_string(url,"p_url"); //将p_url1参数的值复制给arr_url变量 strcpy(arr_url,"URL=http://"); strcat(arr_url,lr_eval_string("{p_url}")); strc