我正在使用 mod_security 2.6.3,我希望能够根据规则严重性级别执行 shell 脚本。我正在使用核心规则集 (CRS),它在检测到攻击时将严重性级别设置为 2(表示“严重”)。
只要严重性足够高,我想执行我的脚本。
我尝试使用该SecDefaultAction
设置,例如:
SecDefaultAction "phase:2,log,deny,status:403,exec:/path/to/my/script"
但是由于“执行”操作是“非破坏性”操作,因此无论触发关键规则还是非关键规则,它总是会被执行。
我可以检查每个关键SecRule
并在其旁边添加“exec”,但这会很乏味(并且重复且丑陋)。
我以为我可以做类似的事情:
SecRule ENV:SEVERITY "@lt 4" "exec:/path/to/my/script"
但不知何故,它永远不会被执行,可能是因为关键规则有一个阻止或拒绝语句来停止规则处理(因为被认为是破坏性的)。
我还尝试使用 CRS 异常评分功能,如下所示:
SecRule TX:ANOMALY_SCORE "@ge 4" "exec:/path/to/my/script"
但它仍然没有得到处理。关于我如何做到这一点的任何想法?