弱电入门工具集 | Wireshark 常用命令

Wireshark是一款网络协议分析工具,可以实时捕获和交互式浏览网络上的数据包。Wireshark 特别强大,门槛也比较高,以下是Wireshark中的一些常用操作和功能,如果有兴趣,可以给我留言,我再出一篇详细教程:

基础知识

常用过滤技巧

TCP连接分析

实际应用与深入学习

思考与拓展

相关资源链接

常用指令:捕获数据包

操作

用途

举例

Start Capture

开始捕获数据包

点击工具栏上的“开始捕获”按钮

Stop Capture

停止捕获数据包

点击工具栏上的“停止捕获”按钮

Open Capture File

打开已保存的捕获文件

选择“文件”>“打开”

Save Capture File

保存捕获的数据包

选择“文件”>“保存”

Apply Display Filter

应用显示过滤器,仅显示符合条件的数据包

在顶部的显示过滤器栏输入条件,如ip.addr == 192.168.1.1

Clear Display Filter

清除当前的显示过滤器

点击显示过滤器栏旁的“清除”按钮

常用指令:分析数据包

操作

用途

举例

Follow TCP Stream

查看TCP流中的数据

右键点击一个TCP数据包,选择“Follow”>“TCP Stream”

Decode As

以特定协议解码数据包

右键点击一个数据包,选择“Decode As”

Statistics

查看网络统计信息

选择“统计”>“协议分级”

Conversations

查看网络会话

选择“统计”>“会话”

Endpoints

查看网络端点

选择“统计”>“端点”

IO Graph

查看输入/输出图表

选择“统计”>“IO图表”

Export Objects

导出数据包中的文件对象

选择“文件”>“导出对象”

常用指令:高级功能

操作

用途

举例

Create Filter

创建并保存自定义过滤器

在显示过滤器栏右键点击,选择“新建过滤器”

Colorize Packet

为特定类型的数据包着色

在数据包列表右键点击,选择“着色规则”

Add or Edit Column

添加或编辑显示列

在数据包列表的列标题右键点击,选择“列首选项”

Set Time Reference

设置时间参考点

在数据包列表右键点击,选择“设置时间参考”

Annotate Packet

为数据包添加注释

在数据包列表右键点击,选择“注释”

Compare Two Capture Files

比较两个捕获文件的差异

使用“文件”>“合并”将两个文件合并,然后进行比较

Wireshark提供了丰富的功能和操作,可以帮助网络分析师深入了解网络通信的细节,定位和解决网络问题。

例子:根据端口过滤,查找服务端主动断开问题

根据端口过滤

服务端端口是7018,和客户端建立socket连接,根据服务端的端口找到2者通信的所有socket数据(客户端进入房间后会异常断开,判断是客户端导致的还是服务端导致的)

tcp.port==7018,最后的RST报文是服务端发起的,说明是服务端主动断开的,缩小问题范围

仅从抓包信息看是服务器的一个流量控制机制启动了。服务器发回rst位,同时win置为0,是告诉客户端不要发包。按tcp流控机制来说,此时客户端应该停止发包,直至服务器发送信息告诉客户端可以继续发送。

标志位说明:

TCP连接:SYN ACK RST UTG PSH FIN
三次握手:发送端发送一个SYN=1,ACK=0标志的数据包给接收端,请求进行连接,这是第一次握手;
接收端收到请求并且允许连接的话,就会发送一个SYN=1,ACK=1标志的数据包给发送端,告诉它,可以通讯了,并且让发送端发送一个确认数据包,这是第二次握手;
最后,发送端发送一个SYN=0,ACK=1的数据包给接收端,告诉它连接已被确认,这就是第三次握手。之后,一个TCP连接建立,开始通讯。

*SYN:同步标志
同步序列编号(Synchronize Sequence Numbers)栏有效。该标志仅在三次握手建立TCP连接时有效。它提示TCP连接的服务端检查序列编号,该序列编号为TCP连接初始端(一般是客户端)的初始序列编号。
在这里,可以把 TCP序列编号看作是一个范围从0到4,294,967,295的32位计数器。通过TCP连接交换的数据中每一个字节都经过序列编号。
在TCP报头中的序列编号栏包括了TCP分段中第一个字节的序列编号。


*ACK:确认标志
确认编号(Acknowledgement Number)栏有效。大多数情况下该标志位是置位的。TCP报头内的确认编号栏内包含的确认编号(w+1,Figure-1)为下一个预期的序列编号,同时提示远端系统已经成功接收所有数据。

*RST:复位标志
复位标志有效。用于复位相应的TCP连接。

*URG:紧急标志
紧急(The urgent pointer) 标志有效。紧急标志置位,

*PSH:推标志
该标志置位时,接收端不将该数据进行队列处理,而是尽可能快将数据转由应用处理。在处理 telnet 或 rlogin 等交互模式的连接时,该标志总是置位的。

*FIN:结束标志
带有该标志置位的数据包用来结束一个TCP回话,但对应端口仍处于开放状态,准备接收后续数据。

TCP的几个状态对于我们分析所起的作用。在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG.其中,对于我们日常的分析有用的就是前面的五个字段。它们的含义是:SYN表示建立连接,FIN表示关闭连接,ACK表示响应,PSH表示有 DATA数据传输,RST表示连接重置。
其中,ACK是可能与SYN,FIN等同时使用的,比如SYN和ACK可能同时为1,它表示的就是建立连接之后的响应,如果只是单个的一个SYN,它表示的只是建立连接。
TCP的几次握手就是通过这样的ACK表现出来的。但SYN与FIN是不会同时为1的,因为前者表示的是建立连接,而后者表示的是断开连接。
RST一般是在FIN之后才会出现为1的情况,表示的是连接重置。一般地,当出现FIN包或RST包时,我们便认为客户端与服务器端断开了连接;
而当出现SYN和SYN+ACK包时,我们认为客户端与服务器建立了一个连接。
PSH为1的情况,一般只出现在DATA内容不为0的包中,也就是说PSH为1表示的是有真正的TCP数据包内容被传递。TCP的连接建立和连接关闭,都是通过请求-响应的模式完成的。

展开阅读全文

页面更新:2024-02-14

标签:过滤器   序列   端口   服务端   客户端   入门   标志   协议   编号   工具   常用命令   数据   网络

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top