在 Wireshark 中如何筛选数据包

1. 显示过滤器(Display Filters)

显示过滤器用于 在已捕获的数据包中筛选,语法类似于编程语言中的条件表达式。

(1)基本过滤

表达式 说明
ip.addr == 192.168.1.1 显示所有涉及 192.168.1.1 的 IP 包
ip.src == 192.168.1.1 显示源 IP 是 192.168.1.1 的包
ip.dst == 192.168.1.1 显示目标 IP 是 192.168.1.1 的包
eth.addr == 00:11:22:33:44:55 按 MAC 地址过滤
tcp.port == 80 显示 TCP 端口 80(HTTP)的流量
udp.port == 53 显示 UDP 端口 53(DNS)的流量

(2)协议过滤

表达式 说明
http 显示所有 HTTP 流量
dns 显示所有 DNS 查询
tcp 显示所有 TCP 流量
udp 显示所有 UDP 流量
icmp 显示所有 ICMP(Ping)流量
ssltls 显示 SSL/TLS 加密流量
arp 显示 ARP 请求/响应
bootpdhcp 显示 DHCP 流量

(3)高级过滤(基于内容)

表达式 说明
http.request.method == "GET" 显示 HTTP GET 请求
http.request.method == "POST" 显示 HTTP POST 请求
http contains "login" 显示 HTTP 请求中包含 "login" 的包
tcp.payload contains "password" 显示 TCP 载荷中包含 "password" 的包
dns.qry.name contains "google.com" 显示查询 google.com 的 DNS 请求
smtp.req.command == "MAIL" 显示 SMTP 邮件发送请求

(4)逻辑运算符(AND/OR/NOT)

| 表达式 | 说明 |
|--------------------------------------------|---------------------------------|-------|------------------|
| tcp.port == 80 && ip.src == 192.168.1.1 | 显示源 IP 192.168.1.1 且端口 80 的流量 |
| `http | | dns` | 显示 HTTP 或 DNS 流量 |
| !arp | 排除所有 ARP 流量 |
| tcp.flags.syn == 1 && tcp.flags.ack == 0 | 显示 TCP SYN 包(用于检测扫描) |

(5)特殊过滤(TCP 状态、错误)

表达式 说明
tcp.analysis.retransmission 显示 TCP 重传包(网络问题)
tcp.analysis.duplicate_ack 显示重复 ACK
tcp.flags.reset == 1 显示 TCP RST(连接重置)包
icmp.type == 3 显示 ICMP 目标不可达错误

2. 捕获过滤器(Capture Filters)

捕获过滤器用于 在抓包时就过滤掉不需要的数据(减少存储量),语法与显示过滤器不同。

(1)基本捕获过滤

表达式 说明
host 192.168.1.1 只抓取涉及 192.168.1.1 的流量
src host 192.168.1.1 只抓取源 IP 是 192.168.1.1 的流量
dst host 192.168.1.1 只抓取目标 IP 是 192.168.1.1 的流量
port 80 只抓取 TCP/UDP 端口 80 的流量
tcp port 443 只抓取 TCP 443(HTTPS)流量
udp port 53 只抓取 UDP 53(DNS)流量

(2)逻辑运算符

表达式 说明
host 192.168.1.1 and port 80 抓取 192.168.1.1 的 80 端口流量
not arp 排除 ARP 流量
src net 192.168.1.0/24 抓取来自 192.168.1.0/24 的流量

3. 如何验证过滤语法?

在 Wireshark 的 Filter 输入框

  • 如果 语法正确 ,输入框背景是 绿色

  • 如果 语法错误 ,输入框背景是 红色

可以点击 Expression... 按钮查看支持的协议和字段。

相关推荐
达斯维达的大眼睛11 分钟前
Linux网络多进程并发服务器和多线程并发服务器
linux·服务器·网络
Lilith的AI学习日记1 小时前
LangChain高阶技巧:动态配置Runnable组件的原理剖析与实战应用
大数据·网络·人工智能·架构·langchain
安科瑞刘鸿鹏1 小时前
智能配电保护:公共建筑安全的新 “防火墙”
运维·网络·物联网·算法·安全·能源
czhc11400756631 小时前
网络5 TCP/IP 虚拟机桥接模式、NAT、仅主机模式
网络·tcp/ip·桥接模式
逆水寻舟1 小时前
尚硅谷2019版Java网络编程笔记
java·网络·笔记
天才测试猿2 小时前
Postman接口测试详解
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
邪恶的贝利亚10 小时前
FFMEPG常见命令查询
linux·运维·网络·ffmpeg
只会写Bug的程序员11 小时前
面试之《websocket》
网络·websocket·网络协议
christine-rr11 小时前
【25软考网工笔记】第二章 数据通信基础(1)信道特性 奈奎斯特 香农定理
网络·信息与通信·信号处理·软考
挣扎的蓝藻12 小时前
使用 Python 扫描 Windows 下的 Wi-Fi 网络实例演示
网络·windows·python