热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

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

本人正在进行网络编程方面的知识整理,想了好长时间不知道该从什么地方开始着手整理,正好最近项目上有个需求,需要在一对设备之间抓包,分析通信双方的数据是否正确。正好借这个机会梳理一下如何利用tcpdump+Wireshark实现TCP数据包的解析。可以说对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端,执行抓包命令:

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进制数据后,我们可以逐项的检查数据的正确性。如果你是自定义协议,就可以将自定义协议,与实际发送数据进行逐一比对。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 我们


推荐阅读
  • centos安装Mysql的方法及步骤详解
    本文介绍了centos安装Mysql的两种方式:rpm方式和绿色方式安装,详细介绍了安装所需的软件包以及安装过程中的注意事项,包括检查是否安装成功的方法。通过本文,读者可以了解到在centos系统上如何正确安装Mysql。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • Python项目实战10.2:MySQL读写分离性能优化
    本文介绍了在Python项目实战中进行MySQL读写分离的性能优化,包括主从同步的配置和Django实现,以及在两台centos 7系统上安装和配置MySQL的步骤。同时还介绍了创建从数据库的用户和权限的方法。摘要长度为176字。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
author-avatar
翟峰
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有