This crate contains several parsers for PCAP and PCAPNG files.
Compared to other similar projects, it is designed to offer a complete support of the many possible formats (legacy pcap, pcapng, little or big-endian, etc.) and features (pcanpng files with multiple sections, interfaces, and endianness) while using only safe code and without copying data (zero-copy).
The code is available on Github and is part of the Rusticata project.
The following code shows how to parse a file in the pcap-ng format, using a PcapNGReader streaming parser.
```rust use pcapparser::*; use pcapparser::traits::PcapReaderIterator; use std::fs::File; use std::io::Read;
let mut file = File::open(path).unwrap(); let mut numblocks = 0; let mut reader = PcapNGReader::new(65536, file).expect("PcapNGReader"); loop { match reader.next() { Ok((offset, _block)) => { println!("got new block"); numblocks += 1; reader.consume(offset); }, Err(PcapError::Eof) => break, Err(PcapError::Incomplete) => { reader.refill().unwrap(); }, Err(e) => panic!("error while reading: {:?}", e), } } println!("numblocks: {}", numblocks); ``` See PcapNGReader for a complete example, including handling of linktype and accessing packet data.
For legacy pcap files, use similar code with the LegacyPcapReader streaming parser.
See pcap-tools and pcap-parse for more examples.
To create a pcap reader for input in either PCAP or PCAPNG format, use the create_reader function.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.