在nginx上安装modsecurity

Kev*_*ien 2 nginx mod-security

今天,我为nginx安装了mod_security.我将以下块添加到/etc/nginx/nginx:

server {
listen       80;
server_name  localhost;

location / {
ModSecurityEnabled on;
ModSecurityConfig modsecurity.conf;
}

}
Run Code Online (Sandbox Code Playgroud)

重新启动Nginx后,我收到以下错误:

nginx: [emerg] unknown directive "ModSecurityEnabled" in /etc/nginx/conf.d/nginx.conf:6
nginx: configuration file /etc/nginx/nginx.conf test failed
Run Code Online (Sandbox Code Playgroud)

产量nginx -V:

nginx version: nginx/1.4.7
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-4) (GCC) 
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_stub_status_module --with-mail --with-mail_ssl_module --with-file-aio --with-ipv6 --with-cc-opt='-O2 -g -pipe -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m32 -march=i386 -mtune=generic -fasynchronous-unwind-tables'
Run Code Online (Sandbox Code Playgroud)

出了什么问题?

cel*_*ver 6

根据官方文件:

nginx服务器的可扩展性模型不包括动态加载的模块,因此必须使用主服务器的源代码编译ModSecurity.由于nginx可在多个基于Unix的平台(以及Windows)上使用,因此目前为nginx获取ModSecurity的推荐方法是在指定环境中进行编译.

资料来源:https://github.com/SpiderLabs/ModSecurity/wiki/Reference-Manual#Installation_for_NGINX

你不能只在nginx.conf中添加一些行来使它工作.

如果您希望得到更有效的帮助,同时参与使Stack Overflow成为更好的地方,您可能还需要考虑以下事项:

  • 在寻求帮助之前阅读文档(我花了3分钟来弄清楚它的工作方式).
  • 为您的问题选择更明确的标题.
  • 尝试自动更正内容以便于阅读.

祝好运!