使用lua编写Wireshark的dissector插件

使用lua编写Wireshark的dissector插件

Dissector 插件可以用来对特定的协议内容进行分析展示,在分析自己实现的应用层协议时还是很有用的。 dissector 插件一般用 C 来实现,具体如何实现可以参考 Wireshark 代码目录下面的 /epan/dissectors 中的源代码和 plugins 目录下面的源代码。

 

一些简单的对性能要求不高的 dissector 插件也可以使用 Lua 来实现。 Wireshark 已经嵌入了对 Lua 的支持。

 

下面就是一个简单的例子:  

 

Java代码 复制代码
  1. -- 定义协议,可以在wireshark中使用trivial过滤   
  2.   
  3. trivial_proto = Proto("trivial","TRIVIAL","Trivial Protocol")   
  4.   
  5.     
  6. -- dissector函数   
  7.   
  8. function trivial_proto.dissector(buffer,pinfo,tree)   
  9.   
  10.     --pinfo的成员可以参考用户手册   
  11.   
  12.     pinfo.cols.protocol = "TRIVIAL"  
  13.   
  14.     pinfo.cols.info = "TRIVIAL data"  
  15.   
  16.     local subtree = tree:add(trivial_proto,buffer(),"Trivial Protocol")   
  17.   
  18.   
  19.     --不对应任何数据   
  20.   
  21.     subtree:add(buffer(0,0),"Message Header: ")   
  22.   
  23.       
  24.     --版本号对应于第一个字节   
  25.   
  26.     subtree:add(buffer(0,1),"Version: " .. buffer(0,1):uint())   
  27.   
  28.       
  29.     --类型对应于第二个字节   
  30.   
  31.     type = buffer(1,1):uint()   
  32.   
  33.     type_str = "Unknown"  
  34.   
  35.     if type == 1 then   
  36.   
  37.         type_str = "REQUEST"  
  38.   
  39.     elseif type == 2 then   
  40.   
  41.         type_str = "RESPONSE"  
  42.   
  43.     end   
  44.   
  45.     subtree:add(buffer(1,1), "Type: " .. type_str)   
  46.   
  47.     
  48.   
  49.     --从第三个字节开始是数据   
  50.   
  51.     size = buffer:len()   
  52.   
  53.     subtree:add(buffer(2,size-2), "Data: ")   
  54.   
  55.          
  56.   
  57. end   
  58.   
  59.     
  60.   
  61. tcp_table = DissectorTable.get("tcp.port")   
  62.   
  63. --注册到tcp的8888端口   
  64.   
  65. tcp_table:add(8888,trivial_proto)  
-- 定义协议,可以在wireshark中使用trivial过滤

trivial_proto = Proto("trivial","TRIVIAL","Trivial Protocol")

 
-- dissector函数

function trivial_proto.dissector(buffer,pinfo,tree)

    --pinfo的成员可以参考用户手册

    pinfo.cols.protocol = "TRIVIAL"

    pinfo.cols.info = "TRIVIAL data"

    local subtree = tree:add(trivial_proto,buffer(),"Trivial Protocol")


    --不对应任何数据

    subtree:add(buffer(0,0),"Message Header: ")

   
    --版本号对应于第一个字节

    subtree:add(buffer(0,1),"Version: " .. buffer(0,1):uint())

   
    --类型对应于第二个字节

    type = buffer(1,1):uint()

    type_str = "Unknown"

    if type == 1 then

        type_str = "REQUEST"

    elseif type == 2 then

        type_str = "RESPONSE"

    end

    subtree:add(buffer(1,1), "Type: " .. type_str)

 

    --从第三个字节开始是数据

    size = buffer:len()

    subtree:add(buffer(2,size-2), "Data: ")

      

end

 

tcp_table = DissectorTable.get("tcp.port")

--注册到tcp的8888端口

tcp_table:add(8888,trivial_proto)

 

 

插件编写完成后保持为 test.lua 文件,我们就可以抓包测试一下了。

 

首先请确认你的 Wireshark 支持 lua ,如果 Wireshark 目录下面有 init.lua 文件就说明支持 Lua 。其次需要启动对 Lua 的支持,默认不启动对 Lua 的支持。编辑 init.lua 文件,注释掉“ disable_lua = true; ”这一行,然后在文件的最后添加一行 dofile("test.lua") ,这样 Wireshark 启动时就会自动调用 test.lua 。也可以在命令行指定需要执行的脚本文件, 比如“ wireshark  -X lua_script:test.lua ”。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值