网络编程(一)TCP数据包的分析

网络 网络管理
本篇文章梳理一下如何利用tcpdump+Wireshark实现TCP数据包的解析。可以说对TCP数据包的分析,是进行网络编程的基础。通过TCP数据包的分析,可以有效的解决网络编程中的好多问题。

本人正在进行网络编程方面的知识整理,想了好长时间不知道该从什么地方开始着手整理,正好最近项目上有个需求,需要在一对设备之间抓包,分析通信双方的数据是否正确。正好借这个机会梳理一下如何利用tcpdump+Wireshark实现TCP数据包的解析。可以说对TCP数据包的分析,是进行网络编程的基础。通过TCP数据包的分析,可以有效的解决网络编程中的好多问题。

利用已有设备,我们部署了如下的网络拓扑图,进行功能测试。选择抓取Server:10.88.65.206与Client:10.88.65.128之间的通信数据。

网络编程(一)TCP数据包的分析

下面开始介绍抓包分析流程:

首先介绍一下测试环境,Server端,IP地址为:10.88.65.206,操作系统为:CentOS6.6。Client端,IP地址为:10.88.65.128,操作系统为:CentOS6.6。抓包工具:tcpdump,CentOS桌面操作系统自带。TCP协议分析工具:Wireshark。

客户端和服务端之间为长连接,为获取这对设备之间的通信数据。通过reboot命令重启Client端设备,让客户端重新连接服务端并发送数据。在重启客户端之前在Server端,执行抓包命令:

  1. tcpdump tcp -i eth0 port 3366 -s 0 -w test.cap 

注意:简单说明下这个命令,在服务端eth0网口的3366端口抓取tcp的完整数据包,并将数据写入test.cap文件。client端和server端会有业务数据的发送,至于是什么业务数据,这取决于你的实际业务。

待客户端启动成功并与服务端的业务数据收发恢复正常后,停止抓包。从服务端机器下载test.cap抓包文件进行分析(可以使用WinSCP、xftp等工具进行下载)。

如果你的电脑上面已经安装Wireshark,无需重复安装,假设你的电脑上面没有安装Wireshark,你需要安装一下。安装完成后,可以直接双击打开test.cap文件。打开后结果如下所示:

网络编程(一)TCP数据包的分析

与服务端通信的不止一台设备,为了快速查看这对设备之间的数据包,可以添加一下过滤条件。

网络编程(一)TCP数据包的分析

经过过滤,我们可以看到剩下的数据全是这两台设备之间的数据。这样更有利于我们进行数据分析。

我们可逐条查看发送数据,直到找到我们需要检查的数据。找到检查的数据后,我们可以点击Data,查看数据是否正确。如图中的灰色部分,是我们测试中发送的业务数据。这里面的数据全是16进制字符串,你可以将你的业务数据也转为16进制字符串来与此数据比对其正确性。

网络编程(一)TCP数据包的分析

得到上面的16进制数据后,我们可以逐项的检查数据的正确性。如果你是自定义协议,就可以将自定义协议,与实际发送数据进行逐一比对。

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2014-07-09 09:43:59

2013-01-28 13:32:52

路由器网络设置数据传输

2021-05-12 00:07:27

TCPIP协议

2011-01-18 13:50:20

路由跟踪tcptracerou

2012-09-04 11:08:57

VMwarevSwitchvSwitch配置

2012-12-04 09:54:33

路由器数据包TCP

2013-05-21 14:41:42

数据包分析内联监控

2017-04-07 09:30:49

Linux网络数据包

2017-03-28 13:25:14

Linux网络数据包

2011-11-28 16:03:49

wireshark数据包

2020-09-03 15:32:08

Wireshark数据包分析

2011-05-19 13:34:50

无线信息包

2019-08-21 05:48:06

TCPIP协议栈

2023-09-11 06:53:46

无线网络数据包

2023-03-27 00:17:21

eBPF技术网络

2013-06-20 13:48:39

2023-03-27 00:13:26

数据包Kubernete网络

2010-09-07 09:12:13

2019-03-28 13:34:22

IP TCP握手

2016-03-15 12:27:54

WireEdit可视化编辑工具网络数据包编辑器
点赞
收藏

51CTO技术栈公众号