python分析wireshark文件

embedded/2024/11/29 15:50:35/

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/embedded/141513.html

相关文章

【Laravel】存储仓Repository基础

laravel 存储仓基础 laravel存储仓基础创建存储仓手动创建存储仓创建接口创建接口实现测试接口 Criteria 封装查询逻辑的模式作用使用场景 使用示例封装商品排序逻辑封装商品状态过滤逻辑业务逻辑封装创建测试控制器测试与结果 laravel存储仓基础 本文基于 Laravel 9.* 版本&a…

linux-cmd

过滤, 管道与重定向 过滤 过滤出 /etc/passwd 文件中包含 root 的记录 grep root /etc/passwd 递归地过滤出 /var/log/ 目录中包含 linux 的记录 grep -r linux /var/log/ 管道 简单来说, Linux 中管道的作用是将上一个命令的输出作为下一个命令的输入, 像 pipe 一样将各个命令…

Leetcode:349. 两个数组的交集

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的! 代码随想录 Leetcode:349. 两个数组的交集 给定两个数组 nums1 和 nums2 ,返回 它们的 交集。输出结果中的每个元素…

Java基础夯实——2.9 多线程如何共享数据

在 Java 多线程编程中,共享数据通过以下几种方式实现: 1. 使用共享对象 多个线程可以通过引用同一个对象来实现数据共享。例如: class SharedData {private int count;public synchronized void increment() {count;}public synchronized …

C/C++基础知识复习(30)

1) 什么是 C 中的 Lambda 表达式?它的作用是什么? Lambda 表达式: 在 C 中,Lambda 表达式是一种可以定义匿名函数的机制,可以在代码中快速创建一个内联的函数对象,而不需要显式地定义一个函数。Lambda 表…

健康养生:开启活力生活的密码

在快节奏的现代生活中,人们越发重视健康养生,追求身体与心灵的和谐共生。 健康养生,饮食为先。我们应遵循 “五谷为养,五果为助,五畜为益,五菜为充” 的理念,确保各类营养物质的均衡摄入。减少油…

Flink 之 Window 机制详解(上):基础概念与分类

《Flink 之 Window 机制详解(上):基础概念与分类》 一、引言 在当今大数据蓬勃发展的时代,Flink 作为一款卓越的分布式流处理和批处理框架,以其独特的架构和强大的功能在数据处理领域占据着重要地位。其底层基于流式…

Mybatis:Mybatis快速入门

Mybatis的官方文档是真的非常好!非常好! 点一下我呗:Mybatis官方文档 MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可…