在 Pyshark 中持续抓包
Continuously capture packets in Pyshark
这篇tutorial and this documentation描述了如何在实时界面中捕获数据包。
但是,您必须指定一个限制(数据包数量或超时)才能开始嗅探:
capture = pyshark.LiveCapture(interface='eth0')
capture.sniff(timeout=50)
或
cap.sniff(packet_count=50)
我的问题:有没有办法在不指定限制的情况下继续捕获数据包?
我可以使用 sniff_continuously() 连续嗅探数据包。下面是一些示例代码,用于连续处理来自网络接口的 TCP 数据包。
def capture_live_packets(network_interface):
capture = pyshark.LiveCapture(interface=network_interface)
for raw_packet in capture.sniff_continuously():
print(filter_all_tcp_traffic_file(raw_packet))
def get_packet_details(packet):
"""
This function is designed to parse specific details from an individual packet.
:param packet: raw packet from either a pcap file or via live capture using TShark
:return: specific packet details
"""
protocol = packet.transport_layer
source_address = packet.ip.src
source_port = packet[packet.transport_layer].srcport
destination_address = packet.ip.dst
destination_port = packet[packet.transport_layer].dstport
packet_time = packet.sniff_time
return f'Packet Timestamp: {packet_time}' \
f'\nProtocol type: {protocol}' \
f'\nSource address: {source_address}' \
f'\nSource port: {source_port}' \
f'\nDestination address: {destination_address}' \
f'\nDestination port: {destination_port}\n'
def filter_all_tcp_traffic_file(packet):
"""
This function is designed to parse all the Transmission Control Protocol(TCP) packets
:param packet: raw packet
:return: specific packet details
"""
if hasattr(packet, 'tcp'):
results = get_packet_details(packet)
return results
capture_live_packets('en0')
这篇tutorial and this documentation描述了如何在实时界面中捕获数据包。 但是,您必须指定一个限制(数据包数量或超时)才能开始嗅探:
capture = pyshark.LiveCapture(interface='eth0')
capture.sniff(timeout=50)
或
cap.sniff(packet_count=50)
我的问题:有没有办法在不指定限制的情况下继续捕获数据包?
我可以使用 sniff_continuously() 连续嗅探数据包。下面是一些示例代码,用于连续处理来自网络接口的 TCP 数据包。
def capture_live_packets(network_interface):
capture = pyshark.LiveCapture(interface=network_interface)
for raw_packet in capture.sniff_continuously():
print(filter_all_tcp_traffic_file(raw_packet))
def get_packet_details(packet):
"""
This function is designed to parse specific details from an individual packet.
:param packet: raw packet from either a pcap file or via live capture using TShark
:return: specific packet details
"""
protocol = packet.transport_layer
source_address = packet.ip.src
source_port = packet[packet.transport_layer].srcport
destination_address = packet.ip.dst
destination_port = packet[packet.transport_layer].dstport
packet_time = packet.sniff_time
return f'Packet Timestamp: {packet_time}' \
f'\nProtocol type: {protocol}' \
f'\nSource address: {source_address}' \
f'\nSource port: {source_port}' \
f'\nDestination address: {destination_address}' \
f'\nDestination port: {destination_port}\n'
def filter_all_tcp_traffic_file(packet):
"""
This function is designed to parse all the Transmission Control Protocol(TCP) packets
:param packet: raw packet
:return: specific packet details
"""
if hasattr(packet, 'tcp'):
results = get_packet_details(packet)
return results
capture_live_packets('en0')