gpt4 book ai didi

rust - 将 pcap 数据包写入没有文件头的文件

转载 作者:行者123 更新时间:2023-11-29 08:13:51 24 4
gpt4 key购买 nike

我有一个 pcap::Packet 并想将它写入没有 pcap 文件头的文件,然后在 Python 中添加文件头。我知道 pcap::Savefile 但不幸的是我不能使用它,因为它会自动写入 pcap 文件头。

How the pcap crate writes the Packet

Description of the pcap data format

我试过类似的东西

extern crate pcap;

use std::{fs::OpenOptions, io::Write, mem, slice};

const DLT_IEEE802_11_RADIO: i32 = 127;
const SNAPLEN: i32 = 4096;

unsafe fn any_as_u8_slice<T: Sized>(p: &T) -> &[u8] {
slice::from_raw_parts((p as *const T) as *const u8, mem::size_of::<T>())
}

fn main() {
let mut capture = pcap::Capture::from_device(pcap::Device::lookup().unwrap())
.unwrap()
.timeout(1)
.rfmon(true)
.snaplen(SNAPLEN)
.open()
.unwrap();

capture
.set_datalink(pcap::Linktype(DLT_IEEE802_11_RADIO))
.unwrap();

let mut temp = OpenOptions::new()
.create(true)
.append(true)
.open("temp.rawpcap")
.unwrap();

let mut count = 0;
while count < 10 {
match capture.next() {
Ok(packet) => {
count += 1;
unsafe {
temp.write_all(any_as_u8_slice(packet.header)).unwrap();
}
temp.write_all(&packet.data).unwrap();
}
Err(pcap::Error::TimeoutExpired) => continue,
Err(e) => {
panic!("unhandled error: {:?}", e);
}
}
}
}

我正在添加 header

import struct

DLT_IEEE802_11_RADIO = 127
SNAPLEN = 4096

pcap_file_header = struct.pack('IHHiIII', 0xa1b2c3d4, 0x2, 0x4, 0, 0, SNAPLEN, DLT_IEEE802_11_RADIO)

with open('temp.rawpcap', 'rb') as f:
data = f.read()

with open('temp.pcap', 'wb') as f:
f.write(pcap_file_header + data)

当我在 Wireshark 中打开结果 .pcap 文件时,我得到了

The capture file appears to be damaged or corrupt.
(pcap: File has 560197-byte packet, bigger than maximum of 262144)

这是每个文件的 hexdump(1 个数据包在 SNAPLEN 为 256 时获取):

$ hexdump -n 56 temp.rawpcap
0000000 d4 c5 8e 5b 00 00 00 00 43 78 02 00 00 00 00 00
0000010 00 01 00 00 50 01 00 00 14 a0 2e 09 01 00 00 00
0000020

$ hexdump -n 56 temp.pcap
0000000 d4 c3 b2 a1 02 00 04 00 00 00 00 00 00 00 00 00
0000010 00 01 00 00 7f 00 00 00 d4 c5 8e 5b 00 00 00 00
0000020 43 78 02 00 00 00 00 00 00 01 00 00 50 01 00 00
0000030 14 a0 2e 09 01 00 00 00
0000038

最佳答案

根据 the pcap data file specification ,时间戳由两个 32 位值组成,但是 pcap::PacketHeader使用 timeval ,它由两个 64 位值组成。

您不能将 header 写成原始的,您需要手写它的字段:

temp.write_all(any_as_u8_slice(&(packet.header.ts.tv_sec as u32))).unwrap();
temp.write_all(any_as_u8_slice(&(packet.header.ts.tv_usec as u32))).unwrap();
temp.write_all(any_as_u8_slice(&packet.header.caplen)).unwrap();
temp.write_all(any_as_u8_slice(&packet.header.len)).unwrap();

由于您没有在任何地方指定字节顺序,因此您还需要确保在与运行 Rust 代码的机器具有相同字节顺序的机器上运行 Python 脚本。

关于rust - 将 pcap 数据包写入没有文件头的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52169131/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com