snort检测插件初始化流程

55 篇文章 3 订阅
22 篇文章 1 订阅

一 检测插件概述

1.代码位置:snort源码src/detection-plugins

2.作用:snort规则体可定义关键词,如对于ICMP协议的itype,icode等,这些关键词及其参数都会被检测插件解析,并调用检测插件相关函数进行处理。如在规则体定义itype:3,那么检测插件会根据输入分组packet结构的icmp协议的type和规则里itype进行比较操作。

二 检测插件Setup

每个检测插件都有Setup函数,例如sp_icmp_type_check.c中的SetupIcmpTypeCheck函数:

void SetupIcmpTypeCheck(void)
{
    RegisterRuleOption("itype", IcmpTypeCheckInit, NULL, OPT_TYPE_DETECTION, NULL);
    ...
}

函数调用链:RegisterRuleOptions=>SetupIcmpTypeCheck=>RegisterRuleOption

1.RegisterRuleOptions定义在plugbase,c中,完成三维链表底层链表(规则体)初始化。

2.RegisterRuleOption定义在plugbase,c中,生成RuleOptConfigFuncNode结点插入链表rule_opt_config_funcs(定义在snort.cc)尾部。

三 检测插件Init

每个检测插件都有Init函数,例如sp_icmp_type_check.c中的IcmpTypeCheckInit函数:

void IcmpTypeCheckInit(struct _SnortConfig *sc, char *data, OptTreeNode *otn, int protocol)
{
    ...
    otn->ds_list[PLUGIN_ICMP_TYPE] = (IcmpTypeCheckData *)SnortAlloc(sizeof(IcmpTypeCheckData)); // 新建结点,挂到三维链表上
    ParseIcmpType(sc, data, otn);                       // 解析icmp规则里的itype值
    fpl = AddOptFuncToList(IcmpTypeCheck, otn);         // 将检测函数挂到otn的相关链表上
}

Init过程完成三维链表中相关键词检测初始化工作,即解析关键词,将关键词检测函数挂接到三维链表中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值