Wireshark 认识捕获的分析数据包(及各个分层协议的介绍)

2024-09-02 13:18

本文主要是介绍Wireshark 认识捕获的分析数据包(及各个分层协议的介绍),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

综述:认识Wireshark捕获数据包

当我们对Wireshark主窗口各部分作用了解了,学会捕获数据了,接下来就该去认识这些捕获的数据包了。Wireshark将从网络中捕获到的二进制数据按照不同的协议包结构规范,显示在Packet Details面板中。为了帮助用户能够清楚的分析数据,本节将介绍识别数据包的方法。

在Wireshark中关于数据包的叫法有三个术语,分别是帧、包、段。下面通过分析一个数据包,来介绍这三个术语。

一、wireshark三个面板介绍

(在edit->Preference->User info->Layout中可修改面板情况 ):

1、"Pcaket List"面板 (包列表)
Packet list/包列表面板显示所有当前捕捉的包
列表中的每行显示捕捉文件的一个包。如果您选择其中一行,该包得更多情况会显示在"Packet Detail/包详情","Packet Byte/包字节"面板
在分析(解剖)包时,Wireshark会将协议信息放到各个列。 因为高层协议通常会覆盖底层协议,您通常在包列表面板看到的都是每个包的最高层协议描述。(在这里高层是应用层,底层是数据链路层)
2、 "Packet Details"面板(包详情)
"Packet Details/包详情"面板显示当前包(在包列表面板被选中的包)的详情列表。
该面板显示包列表面板选中包的协议及协议字段,协议及字段以树状方式组织。你可以展开或折叠它们。
右击它们会获得相关的上下文菜单。
某些协议字段会以特殊方式显示
3、"Packet Byte"面板(包字节)
面板以16进制转储方式显示当前选择包的数据
通常在16进制转储形式中,左侧显示 包数据偏移量,中间栏以16进制表示,右侧显示为对应的ASCII字符  (包数据偏移量是相对第一个包进行偏移)

二、各行信息如下所示:
  Frame:物理层的数据帧概况。
  Ethernet II:数据链路层以太网帧头部信息。
  Internet Protocol Version 4:互联网层IP包头部信息。
  Transmission Control Protocol:传输层的数据段头部信息,此处是TCP协议。
  Hypertext Transfer Protocol:应用层的信息,此处是HTTP协议。
 
下面分别介绍下,帧、包和段内展开的内容。如下所示:
1、物理层的数据帧概况

   Frame 5: 268 bytes on wire (2144 bits), 268 bytes captured (2144 bits) on interface 0   #5号帧,线路268字节,实际捕获268字节
   Interface id: 0                                                                                       #接口id
   Encapsulation type: Ethernet (1)                                                          #封装类型
   Arrival Time: Jun 11, 2015 05:12:18.469086 中国标准时间                 #捕获日期和时间
   [Time shift for this packet: 0. seconds]
   Epoch Time: 1402449138.469086 seconds
   [Time delta from previous captured frame: 0.025257 seconds]            #此包与前一包的时间间隔
   [Time since reference or first frame: 0.537138 seconds]                      #此包与第一帧的时间间隔
   Frame Number: 5                                                                             #帧序号
   Frame Length: 268 bytes (2144 bits)                                                   #帧长度
   Capture Length: 268 bytes (2144 bits)                                                 #捕获长度
   [Frame is marked: False]                                                                    #此帧是否做了标记:否
   [Frame is ignored: False]                                                                    #此帧是否被忽略:否
   [Protocols in frame: eth:ip:tcp:http]                                                      #帧内封装的协议层次结构
   [Number of per-protocol-data: 2]                                                       
   [Hypertext Transfer Protocol, key 0]
   [Transmission Control Protocol, key 0]
   [Coloring Rule Name: HTTP]                                                                #着色标记的协议名称
   [Coloring Rule String: http tcp.port == 80]                                            #着色规则显示的字符串
 

2、数据链路层以太网帧头部信息

   Ethernet II, Src: Giga-Byt_c8:4c:89 (1c:6f:65:c8:4c:89), Dst: Tp-LinkT_f9:3c:c0 (6c:e8:73:f9:3c:c0)
   Destination: Tp-LinkT_f9:3c:c0 (6c:e8:73:f9:3c:c0)                                  #目标MAC地址
   Source: Giga-Byt_c8:4c:89 (1c:6f:65:c8:4c:89)                                        #源MAC地址
   Type: IP (0x0800)
 

3、互联网层IP包头部信息

    Internet Protocol Version 4, Src: 192.168.0.104 (192.168.0.104), Dst: 61.182.140.146 (61.182.140.146)
    Version: 4                                                                                        #互联网协议IPv4
    Header length: 20 bytes                                                                     #IP包头部长度
    Differentiated Services Field: 0x00 (DSCP 0x00: Default; ECN: 0x00: Not-ECT (Not ECN-Capable Transport))         #差分服务字段
    Total Length: 254                                                                                #IP包的总长度
    Identification: 0x5bb5 (23477)                                                              #标志字段
    Flags: 0x02 (Don't Fragment)                                                                #标记字段
    Fragment offset: 0                                                                                #分的偏移量
    Time to live: 64                                                                                    #生存期TTL
    Protocol: TCP (6)                                                                                  #此包内封装的上层协议为TCP
    Header checksum: 0x52ec [validation disabled]                                      #头部数据的校验和
    Source: 192.168.0.104 (192.168.0.104)                                                    #源IP地址
    Destination: 61.182.140.146 (61.182.140.146)                                          #目标IP地址
 

4、传输层TCP数据段头部信息

   Transmission Control Protocol, Src Port: 51833 (51833), Dst Port: http (80), Seq: 1, Ack: 1, Len: 214
    Source port: 51833 (51833)                                                            #源端口号
    Destination port: http (80)                                                              #目标端口号
    Sequence number: 1    (relative sequence number)                           #序列号(相对序列号)
    [Next sequence number: 215    (relative sequence number)]              #下一个序列号
    Acknowledgment number: 1    (relative ack number)                         #确认序列号
    Header length: 20 bytes                                                                  #头部长度
    Flags: 0x018 (PSH, ACK)                                                                   #TCP标记字段
    Window size value: 64800                                                                #流量控制的窗口大小
    Checksum: 0x677e [validation disabled]                                            #TCP数据段的校验和


这篇关于Wireshark 认识捕获的分析数据包(及各个分层协议的介绍)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130062

相关文章

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

Java异常捕获及处理方式详解

《Java异常捕获及处理方式详解》异常处理是Java编程中非常重要的一部分,它允许我们在程序运行时捕获并处理错误或不预期的行为,而不是让程序直接崩溃,本文将介绍Java中如何捕获异常,以及常用的异常处... 目录前言什么是异常?Java异常的基本语法解释:1. 捕获异常并处理示例1:捕获并处理单个异常解释:

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.