当前位置:   article > 正文

python 应用-pcapng包解析(dpkt模块)_python pcapng

python pcapng

介绍

dpkt is a python module for fast, simple packet creation / parsing, with definitions for the basic TCP/IP protocols

dpkt 是一个解析快速简单的TCP/IP协议网络包的python 模块

安装

pip install dpkt

checkout the code

git clone https://github.com/kbandla/dpkt.git

实例

打印packets 实例

This example uses DPKT to read in a pcap file and print out the contents of the packets This example is focused on the fields in the Ethernet Frame and IP packet

打印时间戳 UTC

  1. import datetime
  2. import dpkt
  3. import pcapng
  4. with open("filename",'rb') as fp:
  5. pcapng=dpkt.pcapng.Reader(fp)
  6. for timestamp,buf in pcapng:
  7. print('Timestamp:',str(datetime.datetime.utcfromtimestamp(timestamp)))

输出

Timestamp: 2023-09-06 11:17:45.750188

打印Ethernet Frame 数据链路层信息

  1. with open("filename",'rb') as fp:
  2. pcapng=dpkt.pcap.Reader(fp)
  3. for timestamp,buf in pcapng:
  4. eth = dpkt.ethernet.Ethernet(buf)
  5. ip=eth.data
  6. tcp=ip.data
  7. print('Timestamp:',str(datetime.datetime.utcfromtimestamp(timestamp)))
  8. print("Ethernet Frame:",eth.src,eth.dst,eth.type)
  9. print('source port;',tcp.sport)
  10. print('dst port',tcp.dport)
  11. print('ip len',ip.len)

输出(默认输出为)

  1. Timestamp: 2023-09-06 11:17:45.750188
  2. Ethernet Frame: b'\x02G\x00\x00\x000' b'\x02G\x00\x00\x00\x0e' 2048
  3. source port; 30501
  4. dst port 30501
  5. ip len 1094

打印packet_data 信息

包的第一个block为SectionHeader 信息(cpu, os, wireshark version等);

包的第二个block为InterfaceDescription, 主要是接口的信息, 如以太网网卡信息等

包的第三个block以及往后才开始是EnhancedPacket,若不用打印上述信息,则可以通过计数,从第三个开始打印。
 

  1. with open("filename",'rb') as fp:
  2. scanner = pcapng.FileScanner(fp)
  3. cnt = -2
  4. for block in scanner:
  5. cnt += 1
  6. if cnt > 0:
  7. playload=block.packet_data
  8. # 将二进制数据转换为十六进制字符串
  9. hex_data = binascii.b2a_hex(playload).decode()
  10. # 将十六进制字符串转换为字符串
  11. str_data = hex_data.replace('\\x', '')
  12. print(str_data)

输出(实例)

输出的内容如下:

02470000000e024700000030080

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号