Como instalar o ModSecurity for Nginx no CentOS 7, Debian 8 e Ubuntu 16.04

O ModSecurity é um módulo WAF (firewall de aplicativo da web de código aberto), excelente para proteger o Apache, o Nginx e o IIS de vários ataques cibernéticos que visam vulnerabilidades em potencial em vários aplicativos da web

Neste artigo, instalaremos e configuramos o ModSecurity for Nginx no CentOS 7, Debian 8 e Ubuntu 16.04.

Pré-requisitos

  • Uma instalação atualizada do CentOS 7, Debian 8 ou Ubuntu 16.04 de 64 bits.
  • Fazendo login como root.

Etapa 1: atualizar o sistema

Seguindo este guia , atualize o kernel e os pacotes do servidor para a versão mais recente disponível.

Etapa 2: instalar dependências

Antes de poder compilar o Nginx e o ModSecurity com êxito, é necessário instalar vários pacotes de software da seguinte maneira.

a) No CentOS 7:

yum groupinstall -y "Development Tools"
yum install -y httpd httpd-devel pcre pcre-devel libxml2 libxml2-devel curl curl-devel openssl openssl-devel
shutdown -r now

b) No Debian 8 ou Ubuntu 16.04:

apt-get install -y git build-essential libpcre3 libpcre3-dev libssl-dev libtool autoconf apache2-dev libxml2-dev libcurl4-openssl-dev automake pkgconf

Etapa 3: Compilar ModSecurity

Devido a várias instabilidades relatadas na ramificação mestre do ModSecurity for Nginx, por enquanto, é oficialmente recomendável usar a versão mais recente da nginx_refactoringramificação sempre que possível.

Faça o download da nginx_refactoringramificação do ModSecurity for Nginx:

cd /usr/src
git clone -b nginx_refactoring https://github.com/SpiderLabs/ModSecurity.git

Compile ModSecurity:

a) No CentOS 7:

cd ModSecurity
sed -i '/AC_PROG_CC/a\AM_PROG_CC_C_O' configure.ac
sed -i '1 i\AUTOMAKE_OPTIONS = subdir-objects' Makefile.am
./autogen.sh
./configure --enable-standalone-module --disable-mlogc
make

Nota: os dois sedcomandos acima são usados ​​para evitar mensagens de aviso ao usar versões mais recentes do automake.

b) No Debian 8 ou Ubuntu 16.04:

cd ModSecurity
./autogen.sh
./configure --enable-standalone-module --disable-mlogc
make

Etapa 4: compilar o Nginx

Faça o download e desarquive a versão estável mais recente do Nginx, que está Nginx 1.10.3no momento da redação deste documento:

cd /usr/src
wget https://nginx.org/download/nginx-1.10.3.tar.gz
tar -zxvf nginx-1.10.3.tar.gz && rm -f nginx-1.10.3.tar.gz

a) No CentOS 7:

Primeiro, você precisa criar um usuário dedicado nginxe um grupo dedicado nginxpara o Nginx:

groupadd -r nginx
useradd -r -g nginx -s /sbin/nologin -M nginx

Em seguida, compile o Nginx enquanto habilita os módulos ModSecurity e SSL:

cd nginx-1.10.3/
./configure --user=nginx --group=nginx --add-module=/usr/src/ModSecurity/nginx/modsecurity --with-http_ssl_module
make
make install

Modifique o usuário padrão do Nginx:

sed -i "s/#user  nobody;/user nginx nginx;/" /usr/local/nginx/conf/nginx.conf

b) No Debian 8 ou Ubuntu 16.04:

Primeiro, você deve usar o usuário existente www-datae o grupo existente www-data.

Em seguida, compile o Nginx enquanto habilita os módulos ModSecurity e SSL:

cd nginx-1.10.3/
./configure --user=www-data --group=www-data --add-module=/usr/src/ModSecurity/nginx/modsecurity --with-http_ssl_module
make
make install

Modifique o usuário padrão do Nginx:

sed -i "s/#user  nobody;/user www-data www-data;/" /usr/local/nginx/conf/nginx.conf

Tendo o Nginx instalado com sucesso, os arquivos relacionados estarão localizados em:

nginx path prefix: "/usr/local/nginx"
nginx binary file: "/usr/local/nginx/sbin/nginx"
nginx modules path: "/usr/local/nginx/modules"
nginx configuration prefix: "/usr/local/nginx/conf"
nginx configuration file: "/usr/local/nginx/conf/nginx.conf"
nginx pid file: "/usr/local/nginx/logs/nginx.pid"
nginx error log file: "/usr/local/nginx/logs/error.log"
nginx http access log file: "/usr/local/nginx/logs/access.log"
nginx http client request body temporary files: "client_body_temp"
nginx http proxy temporary files: "proxy_temp"
nginx http fastcgi temporary files: "fastcgi_temp"
nginx http uwsgi temporary files: "uwsgi_temp"
nginx http scgi temporary files: "scgi_temp"

você pode testar a instalação com:

/usr/local/nginx/sbin/nginx -t

Se nada der errado, a saída deve ser:

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

Para sua conveniência, você pode configurar um arquivo de unidade systemd para o Nginx:

cat <<EOF>> /lib/systemd/system/nginx.service
[Service]
Type=forking
ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
ExecReload=/usr/local/nginx/sbin/nginx -s reload
KillStop=/usr/local/nginx/sbin/nginx -s stop

KillMode=process
Restart=on-failure
RestartSec=42s

PrivateTmp=true
LimitNOFILE=200000

[Install]
WantedBy=multi-user.target
EOF

Avançando, você pode iniciar / parar / reiniciar o Nginx da seguinte maneira:

systemctl start nginx.service
systemctl stop nginx.service
systemctl restart nginx.service

Etapa 4: Configurar ModSecurity e Nginx

4.1 Configure o Nginx:

vi /usr/local/nginx/conf/nginx.conf

Encontre o seguinte segmento dentro do http {}segmento:

location / {
    root   html;
    index  index.html index.htm;
}

Insira as linhas abaixo no location / {}segmento:

ModSecurityEnabled on;
ModSecurityConfig modsec_includes.conf;
#proxy_pass http://localhost:8011;
#proxy_read_timeout 180s;

O resultado final deve ser:

location / {
    ModSecurityEnabled on;
    ModSecurityConfig modsec_includes.conf;
    #proxy_pass http://localhost:8011;
    #proxy_read_timeout 180s;
    root   html;
    index  index.html index.htm;
}

Salve e saia:

:wq!

Nota: A configuração do Nginx acima é apenas uma configuração de amostra para o uso do Nginx como servidor da Web, e não como proxy reverso. Se você estiver usando o Nginx como proxy reverso, remova o #caractere nas duas últimas linhas e faça as modificações apropriadas.

4.2 Crie um arquivo chamado /usr/local/nginx/conf/modsec_includes.conf:

cat <<EOF>> /usr/local/nginx/conf/modsec_includes.conf
include modsecurity.conf
include owasp-modsecurity-crs/crs-setup.conf
include owasp-modsecurity-crs/rules/*.conf
EOF

Nota: A configuração acima aplicará todas as Regras Principais do OWASP ModSecurity no owasp-modsecurity-crs/rules/diretório Se você deseja aplicar apenas regras seletivas, remova a include owasp-modsecurity-crs/rules/*.conflinha e especifique as regras exatas necessárias após a etapa 4.5.

4.3 Importar arquivos de configuração do ModSecurity:

cp /usr/src/ModSecurity/modsecurity.conf-recommended /usr/local/nginx/conf/modsecurity.conf
cp /usr/src/ModSecurity/unicode.mapping /usr/local/nginx/conf/

4.4 Modifique o /usr/local/nginx/conf/modsecurity.confarquivo:

sed -i "s/SecRuleEngine DetectionOnly/SecRuleEngine On/" /usr/local/nginx/conf/modsecurity.conf

4.5 Adicione arquivos OWASP ModSecurity CRS (Core Rule Set):

cd /usr/local/nginx/conf
git clone https://github.com/SpiderLabs/owasp-modsecurity-crs.git
cd owasp-modsecurity-crs
mv crs-setup.conf.example crs-setup.conf
cd rules
mv REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf.example REQUEST-900-EXCLUSION-RULES-BEFORE-CRS.conf
mv RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf.example RESPONSE-999-EXCLUSION-RULES-AFTER-CRS.conf

Etapa 5: Testar ModSecurity

Inicie o Nginx:

systemctl start nginx.service

Abra a porta 80 para permitir acesso externo:

a) No CentOS 7:

firewall-cmd --zone=public --permanent --add-service=http
firewall-cmd --reload

b) No Debian 8:

iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD DROP
touch /etc/iptables
iptables-save > /etc/iptables

c) No Ubuntu 16.04:

ufw allow OpenSSH
ufw allow 80
ufw default deny
ufw enable    

Aponte seu navegador para:

http://203.0.113.1/?param="><script>alert(1);</script>

Use greppara buscar mensagens de erro da seguinte maneira:

grep error /usr/local/nginx/logs/error.log

A saída deve incluir várias mensagens de erro semelhantes a:

2017/02/15 14:07:54 [error] 10776#0: [client 104.20.23.240] ModSecurity: Warning. detected XSS using libinjection. [file "/usr/local/nginx/conf/owasp-modsecurity-crs/rules/REQUEST-941-APPLICATION-ATTACK-XSS.conf"] [line "56"] [id "941100"] [rev "2"] [msg "XSS Attack Detected via libinjection"] [data "Matched Data:  found within ARGS:param: \x22><script>alert(1);</script>"] [severity "CRITICAL"] [ver "OWASP_CRS/3.0.0"] [maturity "1"] [accuracy "9"] [tag "application-multi"] [tag "language-multi"] [tag "platform-multi"] [tag "attack-xss"] [tag "OWASP_CRS/WEB_ATTACK/XSS"] [tag "WASCTC/WASC-8"] [tag "WASCTC/WASC-22"] [tag "OWASP_TOP_10/A3"] [tag "OWASP_AppSensor/IE1"] [tag "CAPEC-242"] [hostname ""] [uri "/index.html"] [unique_id "ATAcAcAkucAchGAcPLAcAcAY"]

É isso aí. Como você vê, o módulo ModSecurity registrou esse ataque com êxito, de acordo com sua política de ação padrão. Se você quiser fazer mais configurações personalizadas, revise e edite /usr/local/nginx/conf/modsecurity.confe /usr/local/nginx/conf/owasp-modsecurity-crs/crs-setup.confarquivos com cuidado .

Deixar um comentário

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.