我有一个自定义协议,我正在wireshark中查看。 我认为如果wireshark可以为我解读它,那么我将不需要解码十六进制。虽然我在程序日志中执行此操作,但wireshark会使用时间信息捕获整个会话,因此在那里会更有用。
这可以轻松完成吗?
答案 0 :(得分:27)
您可以使用Wireshark的LUA API编写解剖器。这样你就可以编写一个快速而肮脏的解剖器而无需下载Wireshark的代码,甚至是编译器。 显示了一个非常简单但功能强大的示例in the documentation。 这样的LUA解剖器非常适合调试使用,甚至可以与您的项目一起分发。
如果您打算将解剖器提交到Wireshark官方存储库,您当然应该在性能和集成方面用C实现它。
要使用解剖器,请创建一个文件my_dissector.lua
并像这样调用Wireshark:wireshark -X lua_script:my_dissector.lua
答案 1 :(得分:18)
这取决于您对“轻松”的定义。这绝对可行 - Wireshark对可插拔的解剖器有很大的支持。
README.developer显然是解剖开发的“最佳手册”。看看,自己决定。
答案 2 :(得分:4)