PcapPlusPlus 是一个多平台 C++ 库,用于捕获、解析和制作网络数据包。它旨在高效、强大且易于使用。
PcapPlusPlus 能够解码和伪造各种网络协议。它还为最流行的数据包处理引擎提供易于使用的 C++ 封装,如 libpcap、WinPcap、Npcap、DPDK、eBPF AF_XDP 和 PF_RING。
您可以选择从 GitHub 发布页 面下载,使用包管理器或自行构建 PcapPlusPlus。更多详情请访问 PcapPlusPlus 网站的下载页面。
https://github.com/seladb/PcapPlusPlus/releases/latest
brew install pcapplusplus
Homebrew 公式:https://formulae.brew.sh/formula/pcapplusplus
Windows:
.\vcpkg install pcapplusplus
MacOS/Linux:
vcpkg install pcapplusplus
Vcpkg 端口:https://github.com/microsoft/vcpkg/tree/master/ports/pcapplusplus
conan install "pcapplusplus/[>0]@" -u
ConanCenter 中的包:https://conan.io/center/pcapplusplus
克隆 git 仓库:
git clone https://github.com/seladb/PcapPlusPlus.git
按照 PcapPlusPlus 网站上从源码构建页面中适合您平台的构建说明进行操作。
使用PcapPlusPlus编写应用程序非常简单直观。以下是一个简单的应用程序,展示如何从PCAP文件中读取数据包并解析它:
#include <iostream> #include "IPv4Layer.h" #include "Packet.h" #include "PcapFileDevice.h" int main(int argc, char* argv[]) { // 打开一个pcap文件用于读取 pcpp::PcapFileReaderDevice reader("1_packet.pcap"); if (!reader.open()) { std::cerr << "打开pcap文件出错" << std::endl; return 1; } // 从文件中读取第一个(也是唯一的)数据包 pcpp::RawPacket rawPacket; if (!reader.getNextPacket(rawPacket)) { std::cerr << "无法读取文件中的第一个数据包" << std::endl; return 1; } // 将原始数据包解析为解析后的数据包 pcpp::Packet parsedPacket(&rawPacket); // 验证数据包是否为IPv4 if (parsedPacket.isPacketOfType(pcpp::IPv4)) { // 提取源IP和目标IP pcpp::IPv4Address srcIP = parsedPacket.getLayerOfType<pcpp::IPv4Layer>()->getSrcIPv4Address(); pcpp::IPv4Address destIP = parsedPacket.getLayerOfType<pcpp::IPv4Layer>()->getDstIPv4Address(); // 打印源IP和目标IP std::cout << "源IP为'" << srcIP << "'; 目标IP为'" << destIP << "'" << std::endl; } // 关闭文件 reader.close(); return 0; }
你可以在PcapPlusPlus网站的入门页面找到更多信息。该页面将引导你完成几个简单的步骤,让应用程序运行起来。
PcapPlusPlus由3个库组成:
你可以在PcapPlusPlus网站的API文档部分找到详细的API文档。 如果发现任何缺失的数据,请联系我们。
PcapPlusPlus 目前支持以下平台: Windows <picture> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/65b1f87c-4c34-4631-a764-580a534df982.png" alt="" width="16" height="16"/> </picture>、 Linux <picture> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/64f21be5-c2e6-4a7d-9316-110a9e0b3063.png" alt="" width="16" height="16"/> </picture>、 MacOS <picture><source media="(prefers-color-scheme: dark)" srcset="https://github.com/PcapPlusPlus/pcapplusplus.github.io/raw/master/static/img/os-logos/logo-apple-dark.png"/> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/b6b75cf7-ffa3-443d-b55c-2861794326b5.png" alt="" width="16" height="16"/> </picture>、 Android <picture> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/6293e5e4-e7a7-486c-a8a1-29376d2f7cee.png" alt="" width="16" height="16"/> </picture> 和 FreeBSD <picture> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/26b4cb22-fc03-4f72-b137-8b91a8eefd43.png" alt="" width="16" height="16"/> </picture>。 请访问 PcapPlusPlus 网站查看所有支持的平台,并参考下载部分开始在您的平台上使用 PcapPlusPlus。
PcapPlusPlus 目前支持解析、编辑和创建以下协议的数据包:
数据平面开发套件 (DPDK) 是一组用于快速数据包处理的数据平面库和网络接口控制器驱动程序。
PF_RING™ 是一种新型网络套接字,可显著提高数据包捕获速度。
这两个框架都提供非常快速的数据包处理(最高可达线速),并被用于许多网络应用,如路由器、防火墙、负载均衡器等。 PcapPlusPlus 为 DPDK 和 PF_RING 提供了 C++ 抽象层。这个抽象层提供了一个易于使用的接口,消除了使用这些框架时涉及的许多样板代码。您可以通过访问 PcapPlusPlus 网站上的 DPDK 和 PF_RING 支持页面了解更多信息。
我们使用 Matias Fontanini 的 packet-capture-benchmarks 项目来比较 PcapPlusPlus 与其他类似 C++ 库(如 libtins 和 libcrafter)的性能。
您可以在 PcapPlusPlus 网站的基准测试页面查看结果。
我们非常乐意收到反馈,请随时通过以下任何方式与我们联系:
如果您喜欢这个项目,请在 GitHub 上给我们加星 — 这对我们很有帮助!:star: :star:
请访问 PcapPlusPlus 网站了解更多信息。
我们非常感谢对这个项目的任何贡献。如果您有兴趣贡献,请访问 PcapPlusPlus 网站上的贡献页面。
PcapPlusPlus 根据 Unlicense 许可证发布。


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

