tcpdump抓包工具
一、tcpdump是什么?
tcpdump
命令是一款抓包工具,它可以打印所有经过网络接口的数据包的头信息,也可以使用-w选项将数据包保存到文件中,方便以后通过工具Wireshark
分析。
二、语法
tcpdump (选项)
-a:尝试将网络和广播地址转换成名称;
-c<数据包数目>:收到指定的数据包数目后,就停止进行倾倒操作;
-d:把编译过的数据包编码转换成可阅读的格式,并倾倒到标准输出;
-dd:把编译过的数据包编码转换成C语言的格式,并倾倒到标准输出;
-ddd:把编译过的数据包编码转换成十进制数字的格式,并倾倒到标准输出;
-e:在每列倾倒资料上显示连接层级的文件头;
-f:用数字显示网际网络地址;
-F<表达文件>:指定内含表达方式的文件;
-i<网络界面>:使用指定的网络截面送出数据包;
-l:使用标准输出列的缓冲区;
-n:不把主机的网络地址转换成名字;
-N:不列出域名;
-O:不将数据包编码最佳化;
-p:不让网络界面进入混杂模式;
-q :快速输出,仅列出少数的传输协议信息;
-r<数据包文件>:从指定的文件读取数据包数据;
-s<数据包大小>:设置每个数据包的大小;
-S:用绝对而非相对数值列出TCP关联数;
-t:在每列倾倒资料上不显示时间戳记;
-tt: 在每列倾倒资料上显示未经格式化的时间戳记;
-T<数据包类型>:强制将表达方式所指定的数据包转译成设置的数据包类型;
-v:详细显示指令执行过程;
-vv:更详细显示指令执行过程;
-x:用十六进制字码列出数据包资料;
-w<数据包文件>:把数据包数据写入指定的文件。
三、实例
3.1监视指定网络接口的数据包
tcpdum -i eth1
如果不指定网卡,默认tcpdump
只会监视第一个网络接口,一般是eth0
。
3.2监视指定主机的数据包
截获所有192.168.10.7 的主机收到的和发出的所有的数据包
tcpdump host 192.168.10.7
- 截获主机192.168.10.7 和主机192.168.10.8的通信
tcpdump host 192.168.10.7 and 192.168.10.8
- 截获主机hostname发送的所有数据
tcpdump -i eth0 src host hostname
- 监视所有送到主机hostname的数据包
tcpdump -i eth0 dst host hostname
3.3监视指定主机和端口的数据包
如果想要获取主机192.168.10.7的9999端口的数据包
tcpdump -i eth0 tcp port 9999 and host 192.168.10.7
如果对在同一台机器上的两个程序之间tcp
链接抓包,但就是没有抓到数据包,原因是数据从回环口走了,可用下面命令
tcpdump -i any tcp port 9999 and host 192.168.10.7
四、抓取tcp通信数据包
服务端192.168.10.7
和客户端192.168.10.8
通信,服务端监听9999端口,服务端将客户端发送的消息返回客户端。
抓包命令
sudo tcpdump -i enp0s3 host 192.168.10.7 and 192.168.10.8
完整数据包