【网络编程】tcpdump抓包工具

本文介绍了tcpdump这款抓包工具,包括其基本功能、语法选项,以及如何监视指定网络接口、主机和端口的数据包,最后展示了抓取tcp通信数据包的实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

完整数据包
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值