Resultados 1 al 2 de 2

Tema: Códigos .htaccess que siempre deberias saber

  1. #1 Códigos .htaccess que siempre deberias saber 
    HH Administrator Avatar de LUK
    Fecha de ingreso
    Oct 2001
    Ubicación
    SpaÑa
    Mensajes
    4.966
    Descargas
    178
    Uploads
    246
    Aunque por lo general asociamos .htaccess directamente con seguridad, es posible realizar otras cosas interesantes con estos ficheros. Crear uno de estos archivos es muy simple, podemos usar cualquier editor de texto y al salvarlo estar seguros de que lleva por nombre, exactamente, ".htaccess" -claro está, sin las comillas-.

    Antes de entrar en materia debemos asegurarnos de respaldar cualquier archivo .htaccess presente en el directorio que vamos utilizar para copiar el nuestro, así podremos devolver todo a su estado original en caso de que algo no funcione de la manera que queremos.

    Con esto en mente, pasemos a revisar algunos ejemplos prácticos:

    Crear páginas de error personalizadas

    Ya todos sabemos que los servidores devuelven al cliente diferentes códigos de error cuando algo no anda bien, por ejemplo: el famoso 404 para las páginas no encontradas, 403 para acceso denegado o el temido error 500 que indica un problema interno con el servidor. Con .htaccess es posible redirigir a los visitantes hacia una página mucho más amigable cuando uno de estos errores se presenta. Todo lo que debemos hacer es agregar el siguiente código a nuestro "fichero mágico".

    Código: Text

    1. ErrorDocument 400 /error/400.html
    2. ErrorDocument 401 /error/401.html
    3. ErrorDocument 403 /error/403.html
    4. ErrorDocument 404 /error/404.html
    5. ErrorDocument 500 /error/500.html



    Forzar la descarga de tipos de fichero específicos

    Si en nuestro sitio web ofrecemos acceso a diferentes tipos de archivos como .mp3, .pdf, .xls, etc, podemos establecer una configuración para que estos se descarguen de manera forzada en lugar de permitir al navegador elegir que hacer con ellos. El código para realizar esto es el siguiente y solo debemos modificar la extensión del tipo de archivo que deseamos forzar.

    Código: Text

    1. <Files *.mp3>
    2. ForceType application/octet-stream
    3. Header set Content-Disposition attachment
    4. </Files>
    5. <Files *.xls>
    6. ForceType application/octet-stream
    7. Header set Content-Disposition attachment
    8. </Files>



    Prevenir el Hotlinking

    En el artículo anterior aprendimos lo que significa Hotlinking (o Hotlink) y que es posible prevenirlo gracias a .htaccess. Con el siguiente código evitaremos que otros consuman nuestro valioso ancho de banda.

    Código: Text

    1. RewriteEngine On
    2. #Cambiamos ?mysite.com/ con la url de nuestro sitio
    3. RewriteCond %{HTTP_REFERER} !^http://(.+.)?mysite.com/ [NC]
    4. RewriteCond %{HTTP_REFERER} !^$
    5. #Cambiamos /images/nohotlink.jpg con una imagen que indique que no toleramos los hotlinks
    6. RewriteRule .*.(jpe?g|gif|bmp|png)$ /images/nohotlink.jpg [L]



    Utilizar el cache para aumentar la velocidad de nuestro sitio

    Probablemente este sea uno de los códigos más valiosos de esta lista, ya que nos permitirá acelerar de manera considerable la velocidad de carga de nuestro sitio utilizando el cache. Cada bloque de código a continuación sirve para definir los tipos de archivo que se almacenarán en cache y la cantidad de tiempo -en segundos- que permanecerán allí.

    Código: Text

    1. # 1 Año
    2. <FilesMatch ".(ico|pdf|flv)$">
    3. Header set Cache-Control "max-age=29030400, public"
    4. </FilesMatch>
    5. # 1 Semana
    6. <FilesMatch ".(jpg|jpeg|png|gif|swf)$">
    7. Header set Cache-Control "max-age=604800, public"
    8. </FilesMatch>
    9. # 2 Días
    10. <FilesMatch ".(xml|txt|css|js)$">
    11. Header set Cache-Control "max-age=172800, proxy-revalidate"
    12. </FilesMatch>
    13. # 1 Minuto
    14. <FilesMatch ".(html|htm|php)$">
    15. Header set Cache-Control "max-age=60, private, proxy-revalidate"
    16. </FilesMatch>



    Crear una lista negra de direcciones IP

    Como bien explicaba nuestro compañero JJ, con .htaccess podemos combatir el SPAM de manera agresiva. Una forma de hacerlo es bloqueando las direcciones IP identificadas como fuente de comentarios basura. Copia y pega el siguiente código en el fichero .htaccess de tu servidor y reemplaza las direcciones IP por las que deseas bloquear.

    Código: Text

    1. <Limit GET POST PUT>
    2. order allow, deny
    3. allow from all
    4. deny from 123.123.123.1
    5. deny from 555.555.555.5
    6. deny from 000.000.000.0
    7. </Limit>



    Crear un registro de errores de PHP

    Mientras desarrollabas tu sitio usando PHP o quizá navegando por red, es probable que te hayas encontrado con una página que imprimía algún error de PHP como parte de la "decoración". Estos errores, además de ser desagradables para el usuario común, puede brindar información sensible que puede ser aprovechada por un visitante malintencionado. Para evitar que se impriman en pantalla y, por el contrario, se registren en una bitácora dentro del servidor podemos usar el código a continuación.

    Código: Text

    1. # evitar que los errores se muestren al usuario
    2. php_flag display_startup_errors off
    3. php_flag display_errors off
    4. php_flag html_errors off
    5. # registrar errores en la bítacora
    6. php_flag log_errors on
    7. php_value error_log /logs/php_error.log



    Redireccionar dispositivos móviles

    Si tu sitio no tiene un diseño sensible (responsive web design), quizá te resulte de gran utilidad redirigir el tráfico hacia una versión especialmente preparada para dispositivos móviles.

    Código: Text

    1. RewriteEngine On
    2. RewriteCond %{REQUEST_URI} !^/m/.*$
    3. RewriteCond %{HTTP_ACCEPT} "text/vnd.wap.wml|application/vnd.wap.xhtml+xml" [NC,OR]
    4. RewriteCond %{HTTP_USER_AGENT} "acs|alav|alca|amoi|audi|aste|avan|benq|bird|blac| blaz|brew|cell|cldc|cmd-" [NC,OR]
    5. RewriteCond %{HTTP_USER_AGENT} "dang|doco|eric|hipt|inno|ipaq|java|jigs|kddi|keji |leno|lg-c|lg-d|lg-g|lge-" [NC,OR]
    6. RewriteCond %{HTTP_USER_AGENT} "maui|maxo|midp|mits|mmef|mobi|mot-|moto|mwbp|nec-|newt|noki|opwv" [NC,OR]
    7. RewriteCond %{HTTP_USER_AGENT} "palm|pana|pant|pdxg|phil|play|pluc|port|prox|qtek |qwap|sage|sams|sany" [NC,OR]
    8. RewriteCond %{HTTP_USER_AGENT} "sch-|sec-|send|seri|sgh-|shar|sie-|siem|smal|smar|sony|sph-|symb|t-mo" [NC,OR]
    9. RewriteCond %{HTTP_USER_AGENT} "teli|tim-|tosh|tsm-|upg1|upsi|vk-v|voda|w3cs|wap-|wapa|wapi" [NC,OR]
    10. RewriteCond %{HTTP_USER_AGENT} "wapp|wapr|webc|winw|winw|xda|xda-" [NC,OR]
    11. RewriteCond %{HTTP_USER_AGENT} "up.browser|up.link|windowssce|iemobile|mini|m mp" [NC,OR]
    12. RewriteCond %{HTTP_USER_AGENT} "symbian|midp|wap|phone|pocket|mobile|pda|psp" [NC]
    13. #------------- La siguiente linea excluye al iPad de la lista
    14. RewriteCond %{HTTP_USER_AGENT} !^.*iPad.*$
    15. #-------------
    16. RewriteCond %{HTTP_USER_AGENT} !macintosh [NC] #*SEE NOTE BELOW
    17. RewriteRule ^(.*)$ /m/ [L,R=302]



    Soporte para vídeos en HTML5

    Una de las principales características de HTML5, es la capacidad de reproducir vídeos sin la necesidad de usar plugins, y muchos están aprovechando esta ventaja en sus sitios. Sin embargo, es posible que existan algunos problemas con ciertos formatos de vídeo a la hora de reproducirlos. Alguien que se enfrentó a este inconveniente nos ofrece una solución que utiliza .htacces.

    Código: Text

    1. RewriteCond %{REQUEST_FILENAME} !-f
    2. RewriteCond %{REQUEST_FILENAME} !-d
    3. RewriteCond %{REQUEST_URI} !=/favicon.ico
    4. AddType video/ogg .ogv
    5. AddType video/ogg .ogg
    6. AddType video/mp4 .mp4
    7. AddType video/webm .webm
    8. AddType application/x-shockwave-flash swf



    Redirecciones 301

    Si quieres realizar un cambio de dominio o redirigir el tráfico de una o varias páginas de tu sitio sin ser penalizado por Google -y probablemente otros buscadores-, las redirecciones 301 son la mejor opción. El código .htacces para esto es el siguiente:

    Código: Text

    1. Redirect 301 /d/file.html http://www.domainname.com/r/file.html



    Proteger un archivo específico

    Los servidores almacenan diferentes archivos que guardan la configuración para el funcionamiento del sitio, muchos de estos contienen nombres de usuarios, rutas a bases de datos y contraseñas, información sensible que puede utilizar un usuario malintencionado para poner en jaque la integridad y seguridad de nuestro sitio. Para agregar una capa extra de seguridad y apartar estos archivos de los "curiosos", podemos usar el siguiente método para lanzar un código de error 403. Suponiendo que queremos proteger el archivo wp-config.php de una instalación de WordPress, el código sería:

    Código: Text

    1. <Files wp-config.php>
    2. order allow,deny
    3. deny from all
    4. </Files>



    Proteger un directorio con contraseña

    Con .htaccess también es posible proteger un archivo o directorio completo usando una contraseña. Los códigos para ambos casos se muestran a continuación:

    Código: Text

    1. #Proteger un archivo con contraseña
    2. <files secure.php="">
    3. AuthType Basic
    4. AuthName "Prompt"
    5. AuthUserFile /home/path/.htpasswd
    6. Require valid-user
    7. </files>
    8. #Proteger un directorio con contraseña
    9. resides
    10. AuthType basic
    11. AuthName "This directory is protected"
    12. AuthUserFile /home/path/.htpasswd
    13. AuthGroupFile /dev/null
    14. Require valid-user



    Debes prestar especial atención al archivo .htpasswd ya que este almacena toda la información relacionada con la autenticación de los usuarios.

    Remover www de las URLs de tu sitio

    Para convertir http://www.tusitio.com en http://tusitio.com, basta con agregar el siguiente código a tu archivo .htaccess.

    Código: Text

    1. #remover www de la URL
    2. RewriteEngine On
    3. RewriteCond %{HTTP_HOST} ^www\.domain\.com$ [NC]
    4. RewriteRule ^(.*)$ http://domain.com/$1 [L,R=301]



    Con esto llegamos al final de este pequeño, pero útil e interesante recorrido por el mundo .htaccess. Las dudas y comentarios son siempre bienvenidos y esperamos poder brindar ayuda adicional a través de esta vía.

    Fuente: bitelia
    [][][] LUK [][][]
    hackhispano.com
    Citar  
     

  2. #2  
    Iniciado
    Fecha de ingreso
    Feb 2015
    Ubicación
    Madrid
    Mensajes
    9
    Descargas
    0
    Uploads
    0
    Muchas gracias por la chuleta!lo voy a copiar. Un saludo
    Citar  
     

Temas similares

  1. Todo lo que siempre quiso saber sobre "hackear hotmail"
    Por tamaroque en el foro OFF-TOPIC
    Respuestas: 4
    Último mensaje: 20-02-2016, 13:05
  2. Respuestas: 0
    Último mensaje: 01-07-2014, 13:07
  3. Respuestas: 0
    Último mensaje: 15-10-2008, 14:41
  4. quiero saber como conseguir los codigos mvision 8085
    Por dperez en el foro TELEVISION
    Respuestas: 4
    Último mensaje: 25-07-2006, 23:19
  5. Respuestas: 0
    Último mensaje: 19-07-2006, 02:16

Marcadores

Marcadores

Permisos de publicación

  • No puedes crear nuevos temas
  • No puedes responder temas
  • No puedes subir archivos adjuntos
  • No puedes editar tus mensajes
  •