天天看点

Linux下如何过滤、分割以及合并 pcap 文件Linux下如何过滤、分割以及合并 pcap 文件

Linux下如何过滤、分割以及合并 pcap 文件Linux下如何过滤、分割以及合并 pcap 文件

在这篇文章中,我将介绍一些操作 pcap 文件的工具,以及如何使用它们 。

<a target="_blank"></a>

wireshark,是最受欢迎的 gui 嗅探工具,实际上它带了一套非常有用的命令行工具集。其中包括 editcap 与 mergecap。editcap 是一个万能的 pcap 编辑器,它可以过滤并且能以多种方式来分割 pcap 文件。mergecap 可以将多个 pcap 文件合并为一个。 这篇文章就是基于这些 wireshark 命令行工具的。

如果你已经安装过 wireshark 了,那么这些工具已经在你的系统中了。如果还没装的话,那么我们接下来就安装 wireshark 命令行工具。 需要注意的是,在基于 debian 的发行版上我们可以不用安装 wireshark gui 而仅安装命令行工具,但是在 red hat 及 基于它的发行版中则需要安装整个 wireshark 包。

debian, ubuntu 或 linux mint

$ sudo apt-get install wireshark-common

fedora, centos 或 rhel

$ sudo yum install wireshark

当安装好工具后, 就可以开始使用 editca 与 mergecap 了。

通过 editcap, 我们能以很多不同的规则来过滤 pcap 文件中的内容,并且将过滤结果保存到新文件中。

首先,以“起止时间”来过滤 pcap 文件。 " - a &lt; start-time &gt; 和 " - b &lt; end-time &gt; 选项可以过滤出在这个时间段到达的数据包(如,从 2:30 ~ 2:35)。时间的格式为 “ yyyy-mm-dd hh:mm:ss"。

$ editcap -a '2014-12-10 10:11:01' -b '2014-12-10 10:21:01' input.pcap output.pcap

也可以从某个文件中提取指定的 n 个包。下面的命令行从 input.pcap 文件中提取100个包(从 401 到 500)并将它们保存到 output.pcap 中:

$ editcap input.pcap output.pcap 401-500

使用 "-d &lt; dup-window &gt;" (dup-window可以看成是对比的窗口大小,仅与此范围内的包进行对比)选项可以提取出重复包。每个包都依次与它之前的 &lt; dup-window &gt; -1 个包对比长度与md5值,如果有匹配的则丢弃。

$ editcap -d 10 input.pcap output.pcap

遍历了 37568 个包, 在 10 窗口内重复的包仅有一个,并丢弃。

也可以将 &lt; dup-window &gt; 定义成时间间隔。使用"-w &lt; dup-time-window &gt;"选项,对比&lt; dup-time-window &gt; 时间内到达的包。

$ editcap -w 0.5 input.pcap output.pcap

检索了 50000 个包, 以0.5s作为重复窗口,未找到重复包。

当需要将一个大的 pcap 文件分割成多个小文件时,editcap 也能起很大的作用。

将一个 pcap 文件分割成数据包数目相同的多个文件

$ editcap -c &lt;packets-per-file&gt; &lt;input-pcap-file&gt; &lt;output-prefix&gt;

输出的每个文件有相同的包数量,以 &lt; output-prefix &gt;-nnnn的形式命名。

以时间间隔分割 pcap 文件

$ editcap -i &lt;seconds-per-file&gt; &lt;input-pcap-file&gt; &lt;output-prefix&gt;

如果想要将多个文件合并成一个,用 mergecap 就很方便。

当合并多个文件时,mergecap 默认将内部的数据包以时间先后来排序。

$ mergecap -w output.pcap input.pcap input2.pcap [input3.pcap . . .]

如果要忽略时间戳,仅仅想以命令行中的顺序来合并文件,那么使用 -a 选项即可。

例如,下列命令会将 input.pcap 文件的内容写入到 output.pcap, 并且将 input2.pcap 的内容追加在后面。

$ mergecap -a -w output.pcap input.pcap input2.pcap

你是否使用过 pcap 工具? 如果用过的话,你用它来做过什么呢?

原文发布时间:2015-01-27

本文来自云栖合作伙伴“linux中国”

继续阅读