python分析wireshark文件

ops/2024/12/13 1:38:32/

1 pyshark库

支持wireshark的解析等。

安装pyshark

pip install pyshark

2 dpkt库

这也是一个用于分析pcap文件的库,是所有分析pcap库中最快的一个。

官方参考文档:
https://dpkt.readthedocs.io/en/latest/print_packets.html
https://dpkt.readthedocs.io/en/latest/examples.html#examples-in-dpkt-examples

安装

pip install dpkt

3 应用实例

dpkt读pcap文件

python">f = open('new1.pcap','rb')
pcap = dpkt.pcap.Reader(f)
# ts是timestemp时间戳,buf(二进制数据)是主体的数据包信息。
for ts,buf in pcap:pass

获取每个数据包的ip地址

python">#由buf这个二进制数据转化为Ethernet类的对象
eth = dpkt.ethernet.Ethernet(buf)ip_src = eth.data.src #这里是获取这个数据包的源ip
#要注意的是,这里的源ip是以二进制的方式返回的,如果我们要获取点分十进制的ip地址
#可以这样做
def inet_to_str(inet):try:return socket.inet_ntop(socket.AF_INET,inet)except:return False#这里因为具体需要把IPv6给丢弃了#如果希望IPv6也能获取可以这样#return socket.inet_ntop(socket.AF_INET6,inet)
ip_src = inet_to_str(eth.data.src)
ip_dst = inet_to_str(eth.data.dst)#目的ip\

获取报文中的ip

python">#coding=utf-8
import dpkt
import socket
import timedef inet_to_str(inet):try:return socket.inet_ntop(socket.AF_INET,inet)except:return Falsedef getip():f = open('new1.pcap','rb')#要以rb方式打开,用r方式打开会报错pcap = dpkt.pcap.Reader(f)for ts,buf in pcap:print(ts)打印时间戳eth=dpkt.ethernet.Ethernet(buf)#这里也是对没有IP段的包过滤掉if eth.type != dpkt.ethernet.ETH_TYPE_IP:continueip = eth.dataip_src = inet_to_str(ip.src)ip_dst = inet_to_str(ip.dst)print(ip_src+'-->'+ip_dst)if __name__=='__main__':
getip()

修改报文中的源ip和目的

python">import dpkt
import os
import sockettest = open("new.pcap","wb")
writer = dpkt.pcap.Writer(test)
f=open("old.pcap",'rb')
packets = dpkt.pcap.Reader(f)
for ts,buf in packets:eth = dpkt.ethernet.Ethernet(buf)# 这里是将点分十进制转化成二进制eth.data.src = socket.inet_pton(socket.AF_INET, "192.168.1.1")eth.data.dst = socket.inet_pton(socket.AF_INET, "192.168.1.2")writer.writepkt(eth,ts=ts)#不加ts参数,数据包时间戳会默认为当前时间test.flush()
test.close()

http://www.ppmy.cn/ops/141117.html

相关文章

低代码场景案例配置——复杂数据模型下表单与表格关联字段的保存

主子表的场景是每个业务系统都绕不过的功能点,低代码能不能在业务上用的起来,这个是必须过的门槛。那么什么主子表有哪些场景的应用,如何配置呢,接下来我们就举个例详细说明 订单管理系统,场景描述: 在电…

十一、容器化 vs 虚拟化-Docker 命令

文章目录 常用命令一、容器生命周期管理二、容器操作三、容器的root文件系统(rootfs)命令四、镜像仓库五、本地镜像管理六、info|version七、Docker Compose八、网络命令九、卷命令 常用命令 指令 说明 docker images 查看已下载的镜像 docker rmi 镜像…

深度学习中的损失函数

损失函数是深度学习模型训练过程中不可或缺的一部分,是模型预测值与真实值之间差异的客观衡量标准。它们是模型训练的基础,指导算法调整模型参数,以最小化损失并提高预测准确性。它们衡量了模型预测值与真实值的吻合程度。通过最小化这种损失…

解锁 AI 潜能 - ChatGPT等大模型提示词技巧

在人工智能领域,ChatGPT 等大语言模型正在重新定义我们的工作和生活方式。这些强大的 AI 大模型 能够理解自然语言并生成高质量的内容,无论是撰写文案、解决问题,还是数据分析,都展现了卓越的表现。如何高效使用这些工具&#xff…

【openwrt】openwrt-21.02 基于IP地址使用ipset实现策略路由操作说明

openwrt版本信息 DISTRIB_ID=OpenWrt DISTRIB_RELEASE=21.02-SNAPSHOT DISTRIB_REVISION=r0-6bf6af1d5 DISTRIB_TARGET=mediatek/mt7981 DISTRIB_ARCH=aarch64_cortex-a53 DISTRIB_DESCRIPTION=OpenWrt 21.02-SNAPSHOT r0-6bf6af1d5 DISTRIB_TAINTS=no-all busybox override …

【golang】 WaitGroup使用注意事项

注意1:使用指针 当把WaitGroup作为参数传递给函数时,如果传递的是变量本身(值传递),会发生复制。在 Go 语言中,这种复制可能会导致意外的行为。因为每个WaitGroup副本都有自己独立的计数器。下面的代码如果…

Advanced Functional Materials 光驱动连续跳跃机器人

跳跃是自然界生物的一种非常有效的运动手段,可以在瞬间穿越中长距离,以实现捕猎及逃避被猎捕的目的。自然界生物跳跃的机理主要有两种,长腿动物(比如袋鼠和青蛙)主要依靠杠杆作用,使它们能够用较少的力量跳跃同样的距离&#xff1…

MATLAB 非重叠点云提取算法(92)

MATLAB 非重叠点云提取算法(92) 一、算法介绍二、算法实现1.代码2.结果一、算法介绍 读取两片点云,从一片点云中找到与另一片点云不重叠的点云。输出并可视化提取过程和结果 二、算法实现 1.代码 代码如下(示例): % 假设 cloud1 和 cloud2 是通过 pcread 加载的点云…