要想编译WireShark:

我们需要设置一些环境变量来配置cmake,幸运的是,vscode的CMake插件为我们提供了这个功能,我们只需要在工作区中设置即可:

wireshark怎么编译_CMake

同时需要注意的是,因为wireshark需要C11,但是旧版本的Windows SDK并不支持C11,而我们的"实用C++的桌面开发"恰好默认的是不支持C11的10.0.19,而C11的支持至少是10.0.20348.0,所以注意这一点。我们可以在vs installer中进行修改,如下所示:

wireshark怎么编译_工具链_02

由于一些未知问题,它还会提示我们SDK版本不够,经过测试发现它使用的变量居然为空,为此我们需要自己去设置这个变量

set(CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION 10.0.22000.0)

之后又提示我们需要一个叫LEX的可执行程序。检查自述文件,发现实际需要GNU flex。

https://github.com/westes/flex ,在source forge可以找到预编译的Windows二进制,http://gnuwin32.sourceforge.net/packages/flex.htm

下载解压,并将二进制文件放在有环境变量的文件夹里。然后就可以找到了。

关于QT的依赖可以通过vcpkg的经典模式解决:

vcpkg install qt5-base:x64-windows, qt5-winextras:x64-windows

记得将vcpkg添加到cmake的工具链中。qt5-winextras又需要MFC,好吧,继续安装MFC:

wireshark怎么编译_工具链_03

真的没完没了,在快配置完成的时候,又弹出了两个错误,如下所示:

[cmake] CMake Error in epan/CMakeLists.txt:
[cmake]   Target "epan" INTERFACE_INCLUDE_DIRECTORIES property contains path:
[cmake] 
[cmake]     "D:/base/project/wireshark-4.0.0rc1/wireshark-win64-libs-4.0/vcpkg-export-20220726-1-win64ws/installed/x64-windows/include/glib-2.0"
[cmake] 
[cmake]   which is prefixed in the source directory.
[cmake] 
[cmake] 
[cmake] CMake Error in epan/CMakeLists.txt:
[cmake]   Target "epan" INTERFACE_INCLUDE_DIRECTORIES property contains path:
[cmake] 
[cmake]     "D:/base/project/wireshark-4.0.0rc1/wireshark-win64-libs-4.0/vcpkg-export-20220726-1-win64ws/installed/x64-windows/lib/glib-2.0/include"
[cmake] 
[cmake]   which is prefixed in the source directory.

谷歌之后,发现有人遇到了同样的问题,https://gitlab.com/wireshark/wireshark/-/issues/17477 ,根据描述,发现注释掉epan/CMakeLists.txt的350行那一段代码就行了:

# target_include_directories(epan
# 	SYSTEM PUBLIC
# 		${GLIB2_INCLUDE_DIRS}
# )

真的很烦,编译的时候又提示我出错了!发现了错误在这里:

unknown flag '-'.  For usage, try D:\base\code\utility\tc\flex.exe --help

明显是flex的问题,经过查询,发现了flex版本低了,我真的;经过查询发现了可以使用Win flex-bison,https://sourceforge.net/projects/winflexbison/

真的操作,最后真的要完了的时候,又出错了:

D:\base\vcpkg\installed\x64-windows\bin\libGLESv2.dll does not exist.
D:\base\vcpkg\installed\x64-windows\bin\libEGL.dll does not exist.

突然想起网易云音乐好像有这两DLL,刚好复制过来用。

如果你需要qt被翻译的话,可以添加一个qt5-translations(至少5.15.5,不然有Bug)。

wireshark怎么编译_github_04

终于....

但是我们发现我们的接口列表为空,经过查询我们还需要一个Npcap的东西。

https://github.com/nmap/npcap

没办法,那就累吧。

./build_sdk.bat

获得错误,说必须是VS2019的工具链,但是我是2022的工具链,OK。

使用VS2022打开.\packetWin7\vs14\npcap.sln,VS会自动将其更新到当前版本。

我真的很难,接着发现它还需要一个windows kernel driver的工具库,我靠啊。

https://docs.microsoft.com/en-us/windows-hardware/drivers/download-the-wdk

我们要分别安装SDK和WKD,并且版本要一致。

然后又弹出个错误:

此项目需要缓解了 Spectre 漏洞的库。从 Visual Studio 安装程序(单个组件选项卡)为正在使用的任何 工具集和体系结构安装它们。

算了,放弃了。直接下载二进制吧。

wireshark怎么编译_CMake_05

终于,哈哈哈哈哈!!!!!因为是QT做的UI,所以我顺便把皮肤改成了黑暗颜色,看起来爽多了!