python sniff 过滤器

在 Python 中,可以使用scapy库的sniff函数进行抓包,并通过设置过滤器来筛选感兴趣的数据包。sniff函数的过滤器使用 Berkeley Packet Filter (BPF)语法,以下是一些常用的过滤器示例:

  • 捕获特定主机的数据包host 192.168.1.1
  • 捕获特定端口的数据包port 80
  • 捕获除特定端口外的数据包!port 80
  • 捕获 ICMP 数据包icmp
  • 捕获 TCP 数据包tcp
  • 捕获源地址为特定主机的数据包src host 192.168.1.1
  • 捕获目的地址为特定主机的数据包dst host 192.168.1.1

你可以根据具体的需求组合这些过滤器,例如:filter="tcp and host 192.168.1.1 and port 80" 表示捕获源地址为192.168.1.1、目的端口为80的 TCP 数据包。

以下是一个使用sniff函数进行抓包并设置过滤器的示例代码:

python

from scapy.all import *

# 定义抓包回调函数
def packet_callback(packet):
    print(packet.summary())

# 设置过滤器
filter_condition = "tcp and port 80"

# 开始抓包
sniff(filter=filter_condition, prn=packet_callback)

在上述代码中,首先定义了一个抓包回调函数packet_callback,用于打印抓到的数据包的摘要信息。然后,设置了过滤器filter_condition,只捕获 TCP 协议且端口为80的数据包。最后,使用sniff函数开始抓包,并将过滤器和回调函数作为参数传递给它。

请确保已经安装了scapy库。你可以使用以下命令来安装:

plaintext

pip install scapy

运行上述代码后,它将开始抓取网络上符合过滤器条件的数据包,并打印出每个数据包的摘要信息。你可以根据需要进一步处理和分析抓取到的数据包。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三希

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值