Apache、Mod_security 和 Wordpress,无法按规则 ID 删除

Posted

技术标签:

【中文标题】Apache、Mod_security 和 Wordpress,无法按规则 ID 删除【英文标题】:Apache, Mod_security, and Wordpress, can't remove by rule ID 【发布时间】:2013-05-09 17:54:25 【问题描述】:

我已经环顾四周试图让它正常工作一段时间,最后硬着头皮发帖在这里。

我有一个使用 OWASP 核心规则集 (v 2.2.5) 的带有 ModSecurity 的 LAMP 堆栈,并且刚刚安装了 Wordpress。我预计会与 ModSecurity 发生冲突,但我无法忽略或解决迄今为止我遇到的唯一错误。

Apache error.log 文件和 modsec_audit.log 都列出了相同的错误:

ModSecurity:规则 7f5d9a449228 [id "950901"][file "/etc/modsecurity/owasp-crs/activated_rules/modsecurity_crs_41_sql_injection_attacks.conf"][line "77"] - 执行错误 - 超出 PCRE 限制 (-8): (空)。`

我尝试在 crs conf 文件所在的位置创建一个新的 .conf 文件,其中包含

<LocationMatch .*>
  <IfModule mod_security2.c>
    SecRuleRemoveById 950901
  </IfModule>
</LocationMatch>

甚至删除了IfModule 语句,然后在它不起作用时删除了LocationMatch 语句。

最后我把 .conf 文件中的第 76 行和第 77 行注释掉了,错误仍然出现。这也没有效果。

仅将modsecurity.conf 中的SecRuleEngine 更改为Off 最终让我访问该页面。当然,这违背了ModSec 的目的。

我哪里错了?

【问题讨论】:

【参考方案1】:

尝试将此添加到您的 php.ini 文件(或包含的 conf 文件)中:

pcre.backtrack_limit = 10000000
pcre.recursion_limit = 10000000

然后发给你的modsecurity.conf:

SecPcreMatchLimit 150000
SecPcreMatchLimitRecursion 150000

这应该允许递归而不必完全禁用mod_security

【讨论】:

谢谢!这解决了所有这些错误,但当然我在尝试访问同一页面时仍然收到 403。我尝试将新 ID 添加到我的 whitelist.conf 文件中,但它似乎没有任何效果。我怎样才能获得一个 403 代码来引用我已经消除的 ID 代码(我 99% 确定)? 403 有点通用...您的日志中有什么内容吗?如果您还没有,启用 mod_security 的日志记录可能是个好主意:modsecurity.org/documentation/modsecurity-apache/1.9.3/… 原来我的问题有一半是 wordpress 设置指向错误的存储文件位置,并且没有创建所需文件夹的权限。那是我生命中的 12 个小时,我不会回来。但是感谢您的所有帮助,无论如何我都会合并它

以上是关于Apache、Mod_security 和 Wordpress,无法按规则 ID 删除的主要内容,如果未能解决你的问题,请参考以下文章

在 Amazon Elastic Beanstalk(Apache、EC2)上安装 Mod_security

是否可以安装 Apache mod_security Amazon Elastic Beanstalk

在Apache 上,有个非常重要的安全模块Mod_Security,下面那些是这个模块具备的功能

如何在 .htaccess 文件中禁用 mod_security?

[LAMP]——mod_security和mod_evasive模块的安装

如何安装配置Apache中的mod