en: Test
Estas son 20 recomendaciones para optimizar la seguridad en tu servidor Apache, del mismo modo debes tener en cuenta que algunas de estas recomendaciones pueden disminuir el rendimiento de tu servidor dependiendo de tu configuración y de las especificaciones del sistema.
No tiene sentido poner una cerradura mas resistente a tu puerta si dejas la ventana abierta.Del mismo modo si no tenemos los ultimos parches de seguridad instalado no tendría sentido continuar con la optimización de seguridad.
Si tienes un recurso al que deba solamente tener acceso alguna red, o IP en concreto puedes configurarlo en Apache. Por ejemplo si deseas restringir el acceso a tu Intranet para permitir solamente la red 176.16:
Order Deny,Allow
Deny from all
Allow from 176.16.0.0/16
o por IP:
Order Deny,Allow
Deny from all
Allow from 127.0.0.1
Por defecto muchas instalaciones de Apache muestran el número de versión que está funcionando, el sistema operativo y un informe de módulos de Apache están instalados en el servidor. Los usuario maliciosos pueden utilizar esta información para atacar tu servidor.
Hay dos directivas que necesitas agregar, o corregir en tu archivo de httpd.conf:
ServerSignature Off
ServerTokens Prod
El ServerSignature aparece en la parte inferior de las páginas generadas por apache tales como los famosos errores 404.
La directiva ServerTokens se utiliza para determinarse lo que pondrá Apache en la cabecera de la respuesta HTTP del servidor.
Algunas versiones de Apache corren bajo el usuario nobody, esto compromete mucho su seguridad por lo tanto haz lo siguiente:
User apache
Group apache
El mod_security es un módulo estupendo de Apache escrito por Ivan Ristic, el autor de Apache Security de O’Reilly.
Esta es una lista de cosas que puedes hacer con mod_security:
* Filtración simple
* Filtración basada en expresiónes regular
* Validación de codificación de la URL
* Validación de codificación Unicode
* Auditing
* Prevención del ataque NULL Byte
* Límitar la memoria de subida
* Enmascarar la identidad del servidor
* Y más
Apache viene por defecto instalado con un serie de módulos.Debes echarle un vistazo a la documentación de Apache y ver para que sirve cada uno de ellos, y de esta manera te darás cuenta de que hay algunos que no son útiles en tu servidor.
Busca en httpd.conf las lineas que contengan LoadModule. Para deshabilitar el módulo debes agregar un # al principio de la línea, para que de esta forma pase a ser un comentario. Para buscar los módulos prueba con:
grep LoadModule httpd.conf
Aquí están algunos módulos que se instalan por defecto pero a menudo no son necesarios: mod_imap, mod_include, mod_info, mod_userdir, mod_status, mod_cgi, mod_autoindex.
No deseamos que se pueda acceder a los directorios que no tengan permisos para ello, supongamos que el directorio raiz para nuestras webs es /web, la configuración óptima debera ser la siguiente:
Order Deny,Allow
Deny from all
Options None
AllowOverride None
Order Allow,Deny
Allow from all
Esto lo puedes hacer con las opciones de directiva dentro de la etiqueta directorio tiene dos posibles valores none o indexes.
Options -Indexes
Esto también se hace con las opciones de directiva dentro de la etiqueta directorio tiene dos posibles valores none o include.
Options -Includes
Si no necesitas la ejecución de CGI por algún motivo en concreto desacrivalos se hace con las opciones de directiva dentro de la etiqueta directorio tiene dos posibles valores none o ExecCGI.
Options -ExecCGI
De nuevo se configura con las opciones de directiva dentro de la etiqueta directorio tiene dos posibles valores none o FollowSymLinks.
Options -FollowSymLinks
Si deseas desactivar el uso de todas las opciones simplemente:
Options None
Si solamente deseas desactivar algunas en concreto, separalas con un espacio en las opciones de directiva:
Options -ExecCGI -FollowSymLinks -Indexes
Esto esta ya hecho pero con la directiva AllowOverride. Cámbialo a none.
AllowOverride None
Otra opción interesante sería bloquear la descarga de todos los archivos que comienzen con .ht por ejemplo, se haría de la siguiente manera:
AccessFileName .httpdoverride
Order allow,deny
Deny from all
Satisfy All
Por el defecto el tiempo de espera es de 300 segundos. Puedes disminuirlo por seguridad para prevenir ataques de esta manera:
Timeout 45
Apache tiene varias directivas que permiten que limites el tamaño de una petición, esto puede ser muy útil.
Una buena manera de comenzar es con la directiva LimitRequestBody. Esta directiva esta fijada a ilimitado por defecto. Si estás permitiendo uploads de archivos que no sean mayores a 1MB, podrías fijar este ajuste a algo parecido a esto:
LimitRequestBody 1048576
Si no estás permitiendo uploads de archivos puedes fijarlo incluso a un tamaño más pequeño.
Algunos otras directivas a mirar son LimitRequestFields, LimitRequestFieldSize y LimitRequestLine.
Espero que estas recomendaciones os hayan sido útiles y recuerda que el uso que le tienes que dar depende en gran medida de los recursos que necesitas y de las caracteristicas de tu servidor, antes de hacer cualquier cambio si no estas seguro documéntate y utiliza este artículo unicamente como una referencía que te lleve a la solución más idonea.
8 Respuestas a 20 trucos de seguridad para Apache
Genki
16 de Noviembre de 2007 a las 12:25 pm
Muy buenos trucos, justo ahora estoy empezando a profundizar en apache y esto me viene muy bien
Anónimo
3 de Enero de 2008 a las 2:55 am
Se agradece el esfuerzo de escribir este artículo, pero una mejora en la ortografía se agradecería mucho más.
Saludos
calitos
29 de Agosto de 2008 a las 1:20 pm
Saludos,
Soy nuevo configurando servidores y es por eso que necesito ayuda.
He instalado apache , php, mysql, phpmyadmin, y ha quedado muy bien tal es asi que todo funciona en mi servidor, pero he querido que mi web tenga salida por internet para ello ingrese a dyndns para tener un dominio ya que mi ip es dinamica ademas de haber instalado ddclient para que actualice mi ip. Otra de las cosas que hice fue abrir los puertos de mi router zyxel 650H y los redireccione al ip de mi servidor para que cada vez que llamen al dominio este se conecte a mi ip publica, este a mi puerto 80 de mi router y este a mi ip de mi servidor mostrando mi web.
He aqui mi problema: cuando hago el pedido desde una pc fuera de mi lan sobre mi dominio de servidor este me pide contraseña usuario para poder conectarme al servidor…Quisiera saber por que sucede esto??? Que debo hacer para que muestre mi web y no me pida usuario y contraseña…He pensado que es por la configuracion de apache pero puedo estar equivocado.
Les agradezco de antemano su ayuda, necesito que me ayuden por favor.
Flavio Camus
11 de Diciembre de 2008 a las 11:36 am
Una buena manera de probar antes de reiniciar el server y que todo se estropee es usar:
apachectl configtest
, para probar que la configuracion va bien y luego
apachectl graceful
,para reiniciar “amablemente” el servidor y que no se note en las conexiones de los usuarios.
Eso,
Muy buenos datos!
20 trucos de seguridad para Apache | Distro-Geek...
23 de Octubre de 2009 a las 9:26 pm
[...] en: tufuncion Compartir Hide [...]
uno mas de la red
1 de Noviembre de 2009 a las 10:41 am
Siempre tiene que saltar un capullazo con lo de… mejor, mejora la ortografia…. desagradecidos los hay en todos los paises!
En fin, no he probado nada de lo que publicas, pero gracias por la info.
Siempre se agradece desde aqui, el mero hecho de compartir.
Mejorar la seguridad en Apache |~| Oloroko Blog
31 de Diciembre de 2009 a las 9:22 pm
[...] Fuente Posted by Oloroko @ 31 December 2009 0 comments Tags : Apache , Localhost , WebMaster [...]
oscar
31 de Mayo de 2010 a las 11:06 pm
muy buena la informacion, he tenido la oportunidad de configurar el apache y lo que dices es cierto, aun que el apache es bastante extenso lo que dices es un buen resumen.. saludos