百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

巧妙的使用 tcpdump 查看原始数据包

haoteby 2025-04-30 16:52 37 浏览

使用 'tcpdump' 查看原始数据包

虽然像 Snort 这样的工具在筛选通过我们网络的所有内容方面做得非常出色,但有时需要查看原始数据。为此,我们最好的工具是“tcpdump”。

使用 tcpdump 最基本的方法是简单地发出命令:

您可以使用 -v 选项获得更多详细信息,使用 -vv 可以获得更多信息。

有用的选项

假设您已登录到您管理的远程计算机。通常,您将使用 SSH。如果您在没有任何选项的情况下运行“tcpdump”,则输出将被来自您的 SSH 连接的数据包淹没。为避免这种情况,只需从输出中删除端口 22:

您可以使用许多不同的端口来执行此操作:

代码:

tcpdump not port 143 and not port 25 and not port 22

如果你想做相反的事情,即只监视某个端口——这对调试网络应用程序很有好处——你可以执行以下操作:

您还可以从网络上的特定主机获取数据:

如果您的机器有多个网络接口,您还可以指定要收听的一个:

您还可以指定协议:

您将在 /etc/protocols 中找到协议列表。

为以后保存输出

在某些情况下,您可能希望将输出重定向到一个文件,以便以后可以详细研究它或使用其他程序来解析输出。在以下示例中,您仍然可以在将输出保存到文件时查看输出:

代码:

tcpdump -l | tee tcpdump_`date +%Y%m%e-%k.%M`

在上面的示例中,我们可以使用日期和时间来识别每个转储。在处理一天中某些时间出现的问题时,这可能会派上用场。

tcpdump 还可以选择将其输出转储为二进制格式,以便以后读取。创建二进制文件:

代码:

tcpdump -w tcpdump_raw_`date +%Y%m%e-%k.%M`

稍后,您可以使用 tcpdump 读取文件

代码:

tcpdump -r tcpdump_raw_YYYMMDD-H.M

您还可以使用 ethereal 程序打开原始转储并对其进行解释。我们将在下一节中更多地讨论空灵。

要查找的内容

tcpdump 为我们提供了有关进出我们网络的所有数据包的信息。但这一切意味着什么?

将 Ethereal 与 tcpdump 结合使用 Ethereal

是一个也可用于捕获网络数据包的工具。安装后,您可以打开您制作的原始转储文件。它看起来像这样:

这使得查看正在发生的事情变得相当容易。您可以看到源 IP 和目标 IP 是什么以及它是什么类型的数据包。然后很容易解决您可能遇到的网络问题并分析可疑行为。顺便说一句,当我在写这节课并解释我自己的转储时,我在我的个人工作站上看到了一些奇怪的活动。几乎每隔一段时间,我就会在世界上不同 IP 的机器上查询端口 32772。我为端口 32772 运行了一个特定的转储,如下所示:

代码:

tcpdump port 32772 -w dump_32772

我得到的确实看起来很奇怪。即使在谷歌搜索之后,我也找不到任何相关信息,所以我怀疑我可能有木马。我运行了“rootkit hunter”(下一节将详细介绍),但结果却一无所获。最后,一一关机,原来是我一直打开的Skype。尽管这被证明是无害的,但我很高兴我有 tcpdump 向我指出这一点。

读取原始输出

如您所见,即使从 tcpdump 读取所谓的“人类可读”输出也可能有点神秘。看看下面的例子,一个我刚刚从转储中捞出的随机数据包:

代码:

17:26:22.924493 IP www.linux.org.www > test.linux.org.34365: P 2845:3739(894) ack 1624 win 9648 <nop,nop,timestamp 326501459 24374272>

我们拥有的是对www.linux.org的网络服务器请求. 在时间戳之后,您会注意到主机名末尾的 .www(表示端口 80)。这将被发送到请求主机 test.linux.org 的端口 34365。'P' 代表 TCP “oush” 功能。这意味着应该立即发送数据。在后面的数字中,2845:3739(894),2845 标记了第一个数据包的八位字节数。数字 3739 是数据包发送的最后一个字节的编号加 1。数字 894 是发送的数据包的长度。上面写着:“ack 1624”的部分是“acknowledge”的 TCP 术语——即数据包已被接受,接下来预期的数据包号是 1624。之后,我们看到“win 9648”发送主机等待窗口大小为 9648 个八位字节的数据包。这后面是时间戳。

现在,如果您认为这有点难以解释,如果您使用 -x 选项,它将在十六进制输出中包含数据包内容。在这里,您需要埃及学家来解释输出:

代码:

18:12:45.149977 IP www.linux.org.www > test.linux.org.34536: . 1:1449(1448) 
ack 487 win 6432 <nop,nop,timestamp 329284215 27156244>
        0x0000:  4500 05dc 6a81 4000 4006 493b c0a8 0006  E...j.@.@.I;....
        0x0010:  c0a8 0009 0050 86e8 8fa4 1d47 1c33 e3af  .....P.....G.3..
        0x0020:  8010 1920 b4d9 0000 0101 080a 13a0 7a77  ..............zw
        0x0030:  019e 5f14 4854 5450 2f31 2e31 2032 3030  .._.HTTP/1.1.200
        0x0040:  204f 4b0d 0a44 6174 653a 2054 6875 2c20  .OK..Date:.Thu,.
        0x0050:  3135

我们可以从输出中收集到,这是一个 HTTP 请求。至于其余的,它不是人类可读的,但我们很容易知道这是一个合法的数据包。使用这种格式的另一个好处是,即使我们不能准确地解释这个数据包发生了什么,我们也可以将它发送给可能能够理解的人。最后,这是未经任何过滤就通过网络传输的原始数据。

相关推荐

一日一技:用Python程序将十进制转换为二进制

用Python程序将十进制转换为二进制通过将数字连续除以2并以相反顺序打印其余部分,将十进制数转换为二进制。在下面的程序中,我们将学习使用递归函数将十进制数转换为二进制数,代码如下:...

十进制转化成二进制你会吗?#数学思维

六年级奥赛起跑线:抽屉原理揭秘。同学们好,我是你们的奥耀老师。今天一起来学习奥赛起跑线第三讲二进制计数法。例一:把十进制五十三化成二进制数是多少?首先十进制就是满十进一,二进制就是满二进一。二进制每个...

二进制、十进制、八进制和十六进制,它们之间是如何转换的?

在学习进制时总会遇到多种进制转换的时候,学会它们之间的转换方法也是必须的,这里分享一下几种进制之间转换的方法,也分享两个好用的转换工具,使用它们能够大幅度的提升你的办公和学习效率,感兴趣的小伙伴记得点...

c语言-2进制转10进制_c语言 二进制转十进制

#include<stdio.h>intmain(){charch;inta=0;...

二进制、八进制、十进制和十六进制数制转换

一、数制1、什么是数制数制是计数进位的简称。也就是由低位向高位进位计数的方法。2、常用数制计算机中常用的数制有二进制、八进制、十进制和十六进制。...

二进制、十进制、八进制、十六进制间的相互转换函数

二进制、十进制、八进制、十六进制间的相互转换函数1、输入任意一个十进制的整数,将其分别转换为二进制、八进制、十六进制。2、程序代码如下:#include<iostream>usingna...

二进制、八进制、十进制和十六进制等常用数制及其相互转换

从大学开始系统的接触计算机专业,到现在已经过去十几年了,今天整理一下基础的进制转换,希望给还在上高中的表妹一个入门的引导,早日熟悉这个行业。一、二进制、八进制、十进制和十六进制是如何定义的?二进制是B...

二进制如何转换成十进制?_二进制如何转换成十进制例子图解

随着社会的发展,电器维修由继电器时代逐渐被PLC,变频器,触摸屏等工控时代所替代,特别是plc编程,其数据逻辑往往涉及到数制二进制,那么二进制到底是什么呢?它和十进制又有什么区别和联系呢?下面和朋友们...

二进制与十进制的相互转换_二进制和十进制之间转换

很多同学在刚开始接触计算机语言的时候,都会了解计算机的世界里面大多都是二进制来表达现实世界的任何事物的。当然现实世界的事务有很多很多,就拿最简单的数字,我们经常看到的数字大多都是十进制的形式,例如:我...

十进制如何转换为二进制,二进制如何转换为十进制

用十进制除以2,除的断的,商用0表示;除不断的,商用1表示余0时结束假如十进制用X表示,用十进制除以2,即x/2除以2后为整数的(除的断的),商用0表示;除以2除不断的,商用1表示除完后的商0或1...

十进制数如何转换为二进制数_十进制数如何转换为二进制数举例说明

我们经常听到十进制数和二进制数,电脑中也经常使用二进制数来进行计算,但是很多人却不清楚十进制数和二进制数是怎样进行转换的,下面就来看看,十进制数转换为二进制数的方法。正整数转二进制...

二进制转化为十进制,你会做吗?一起来试试吧

今天孩子问把二进制表示的110101改写成十进制数怎么做呀?,“二进制”简单来说就是“满二进一”,只用0和1共两个数字表示,同理我们平常接触到的“十进制”是“满十进一”,只用0-9共十个数字表示。如果...

Mac终于能正常打游戏了!苹果正逐渐淘汰Rosetta转译

Mac玩家苦转译久矣!WWDC2025苹果正式宣判Rosetta死刑,原生游戏时代终于杀到。Metal4光追和AI插帧技术直接掀桌,连Steam都连夜扛着ARM架构投诚了。看到《赛博朋克2077》...

怎么把视频的声音提出来转为音频?音频提取,11款工具实测搞定

想把视频里的声音单独保存为音频文件(MP3/AAC/WAV/FLAC)用于配音、播客、听课或二次剪辑?本文挑出10款常用工具,给出实测可复现的操作步骤、优缺点和场景推荐。1)转换猫mp3转换器(操作门...

6个mp4格式转换器测评:转换速度与质量并存!

MP4视频格式具有兼容性强、视频画质高清、文件体积较小、支持多种编码等特点,适用于网络媒体传播。如果大家想要将非MP4格式的视频转换成MP4的视频格式的话,可以使用MP4格式转换器更换格式。本文分别从...