抓包- tcpdump-wireshark
发表于2017-08-28 16:43 | 次阅读 | 0条评论 | 作者:siru90
tcpdump 与wireshark
Wireshark(以前是ethereal)是Windows下非常简单易用的抓包工具。
但在Linux下很难找到一个好用的图形化抓包工具, 还好有tcpdump。我们可以用tcpdump + Wireshark 的完美组合实现:在 Linux 里抓包,然后通过wineshark的过滤语法来找到相应的数据包。
tcpdump tcp -i eth1 -t -s 0 -c 100 and dst port ! 22 and src net 192.168.1.0/24 -w ./target.cap
(1)tcp: ip icmp arp rarp 和 tcp、udp、icmp这些选项等都要放到第一个参数的位置,用来过滤数据报的类型
(2)-i eth1 : 只抓经过接口eth1的包
(3)-t : 不显示时间戳
(4)-s 0 : 抓取数据包时默认抓取长度为68字节。加上-S 0 后可以抓到完整的数据包
(5)-c 100 : 只抓取100个数据包
(6)dst port ! 22 : 不抓取目标端口是22的数据包
(7)src net 192.168.1.0/24 : 数据包的源网络地址为192.168.1.0/24
(8)-w ./target.cap : 保存成cap文件,方便用ethereal(即wireshark)分析
yum install -y tcpdump #安装tcpdump
tcpdump --help #查看使用方法
例子:截取本机(127.0.0.1)和主机(192.168.1.155)之间的数据
tcpdump -n -i eth0 host 127.0.0.1 and 192.168.1.155
tcpdump port 80 -w aa.cap #抓取端口80,并保存到aa.cap文件中