Está en la página 1de 6

Cómo utilizar .

htaccess
http://info.cdmon.com

Cómo utilizar .htaccess


¿Qué es un .htaccess?

El .htaccess (Acceso de Hiper-Texto) es el nombre por defecto del archivo de configuración de directorios de
Apache. Se utiliza para personalizar la configuración de directivas y parámetros definidos en el archivo de
configuración principal del alojamiento. Tiene una gran variedad de usos y utilidades que le pueden resultar útiles
en su web. En el siguiente tutorial le mostramos algunas de las funciones más utilizadas por el .htaccess.

Cómo crear y dónde colocar un fichero .htaccess?

Para crear un fichero .htaccess, abra el bloc de notas e introduzca el código necesario. Guarde el fichero como
fichero de texto (.txt), por ejemplo "fichero_htaccess.txt", y súbalo por FTP en la carpeta donde tiene que utilizarse.
Una vez en el servidor, modifique el nombre del fichero "fichero_htaccess.txt" por el de ".htaccess".

El .htaccess debe colocarse en el interior de la carpeta donde queremos que tenga efecto. Por ejemplo, si
queremos proteger con contraseña una carpeta llamada "privado", colocaremos el .htaccess dentro de la carpeta
"privado".

Utilidades comunes  del .htaccess

El .htaccess tiene un gran número de utilidades, en este tutorial le mostramos algunas de las utilidades más
comunes y cómo debe configurarse en el fichero .htaccess

Control de acceso al sitio

Podemos hacer que, si por alguna razón deseamos denegar el acceso a todos los usuarios o sólo permitir a un
cierto grupo de direcciones IP para que tengan acceso a tu sitio.

Para permitir el acceso a tu sitio solo a ciertas IPs:

ErrorDocument 403 http://www.mi-url.com


Order deny,allow
Deny from all
Allow from 124.34.48.165
Allow from 102.54.68.123

Las IPs 124.34.48.165 y 102.54.68.123 son las IPs que tendrán acceso a la web.

Denegar el acceso al sitio solo a ciertas IPs:

Allow from all


Deny from 145.186.14.122
Deny from 124.15

La IP 145.186.14.122 y la red 124.15.x.x no tendrán acceso a la web.

Control de acceso a carpetas

Un uso muy común del .htaccess es impedir el acceso a algunas carpetas. Puede ser que queramos deshabilitar

1/6
Cómo utilizar .htaccess
http://info.cdmon.com

totalmente el acceso a una carpeta (por ejemplo, una carpeta con librerías de programación que se incluyen en los
archivos principales. En este caso sólo los archivos principales accederán a ellos mediante el sistema de archivos,
pero no se podrán acceder via web). Bueno, simplemente creamos un archivo .htaccess en esa carpeta que
contenga el siguiente codigo si deseamos:

Prohibir o deshabilitar por completo el acceso a una carpeta:

#deny all access


deny from all

Permitir el acceso desde una IP específica:

#deny all access


deny from all
allow from 212.267.98.14

Permitir el acceso a un rango específico de IPs (forzado mediante la máscara de red):

allow from 192.168.0.0/24

Bloquear el acceso a un archivo específico:

<Files archivo.html>
Order allow,deny
Deny from all

Listado de carpetas

También podemos utilizar el .htaccess para mostrar el contenido de una carpeta en la estructura de directorios.

Options +Indexes

Listado de carpetas, pero no queremos que se nos muestren los iconos por defecto:

Options +Indexes
IndexOptions -FancyIndexing

También se podría querer evitar el listado de carpetas:

IndexIgnore *

Redirigir web

Si al acceder a su alojamiento, desea redirigir la página a otra:

RewriteEngine On
RewriteRule ^(.*)$ http://www.webaredirigir.com/$1 [R=301,L]

Redirigir peticiones a subcarpeta

Si tenemos la web en una subcarpeta diferente de la carpeta "web", podemos redirigir todas las consultas a esta
subcarpeta:

RewriteEngine on

2/6
Cómo utilizar .htaccess
http://info.cdmon.com

RewriteCond % ^midominio.com\.com$
RewriteRule (.*) http://www.midominio.com/$1 [R=301,L]
RewriteRule ^$ carpeta [L]

donde:
midominio.com\.com sería, por ejemplo, cdmon\.com.com
carpeta sería, por ejemplo, wordpress

Redirigir peticions amb www.domini.com a domini.com i a la inversa


Si queremos que nuestra web se vea siempre sin www, añadimos el segiente código en el .htaccess:

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond % !-f
RewriteCond % !-d
RewriteRule . /index.php [L]
RewriteCond % ^www\.midominio.com [NC]
RewriteRule ^(.*)$ http://midominio.com/$1 [L,R=301]
</IfModule>

I al revés, que la web se vea siempre con www:

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond % !-f
RewriteCond % !-d
RewriteRule . /index.php [L]
RewriteCond % ^\.midominio.com [NC]
RewriteRule ^(.*)$ http://www.midominio.com/$1 [L,R=301]
</IfModule>

donde:
midominoi.com podría ser, por ejemplo, cdmon.com

Redirigir web amigable con SEO

Si has transferido nombres de dominio o deseas redireccionar a una página específica sin que afecte a los
resultados de los motores de búsqueda como Google, utiliza el siguiente código:

Redirect 301 /d/nombredelarchivo.html http://www.mi-url.com

Redireccionar el tráfico web

Si lo que deseamos es que si alguien intenta acceder a un archivo en concreto le redirija a otro fichero, podemos
utilizar la directiva Redirect:

Redirect /fichero.php http://sudominio.com/otros/nuevofichero.php

Redireccionar a conexión segura HTTPS

Si deseamos redireccionar todo nuestro sitio a una conexión segura (HTTPS), esto es muy util si por ejemplo

3/6
Cómo utilizar .htaccess
http://info.cdmon.com

disponemos de un certificado SSL y queremos trabajar con el.

RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://www.midominio.com/$1 [R,L]

Redireccionar usuarios para usar HTTPS para una carpeta en particular

Si lo que deseamos es solo redireccionar a una conexión segura (HTTPS) una carpeta en particular en vez de
todo el sitio, por ejemplo tenemos una tienda en una carpeta aparte de nuestro sitio, hay que usar el siguiente
codigo.

RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteCond %{REQUEST_URI} nombre_de_la_carpeta
RewriteRule ^(.*)$ https://www.midominio.com/nombre_de_la_carpeta/$1 [R,L]

Evitar el hotlinking

El hotlinking consiste en realizar un enlace directo a ficheros, generalmente imágenes y vídeos, que pertenecen a
otra web. Esta práctica consume la transferencia del sitio original de la imagen. Para evitar que nos "roben" ancho
de banda podemos configurar el .htaccess para impedir el hotlinking. RewriteEngine on

# Options +FollowSymlinks
RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http://(www\.)?midominio.com/.*$ [NC]

Ahora falta la ultima linea que puede ser para prohibir que contenido no deseamos (se escoje en función de las
extensiones de los archivos) que nos cojan:

RewriteRule .*\.(jpe?g|gif|bmp|png)$ [L]

O bien esta otra regla que además muestra un archivo (no_robar_ancho_de_banda.gif que debemos haber creado
previamente) para advertir que esta imagen esta siendo cogida de nuestro site.

RewriteRule .*.(gif|jpg|png)$ http://midominio.com/img/no_robar_ancho_de_banda.gif[nc]

En la última línea ponemos las extensiones de los ficheros que queremos impedir que los enlacen.

Cambiar la pagina por defecto

Puedes hacer que la página indice de tu sitio a mostrar no sea la archiconocida "index". Aquí seteamos
"about.html" como página de inicio:

#Serve Alternate Default Index Page


DirectoryIndex about.html

Quitar palabras o strings de una URL

Esta opción sirve para evitar que la gente conozca nuestro arbol de rutas de nuestro alojamiento con ello
incrementamos la seguridad a la vez que hacemos la dirección más atractiva. En este ejemplo, quitaremos la

4/6
Cómo utilizar .htaccess
http://info.cdmon.com

palabra "category" de nuestras URL.

Es decir: http://tudominio.com/category/blue -> http://tudominio.com/blue

Agrega este código al final de tu .htaccess

RewriteRule ^category/(.+)$ http://www.midominio.com/$1 [R=301,L]

Forzar el cacheo de nuestro sitio

El siguiente snippet no va a incrementar directamente la velocidad de carga del sitio en general, pero sí va a
cargar más rápido cuando el mismo usuario vuelva a visitarlo, al enviar un status 304 cuando se pidan elementos
que no han sido modificados. Puedes cambiar la frecuencia de cacheo al cambiar el número de segundos (en este
ejemplo se da una vez al día):

FileETag MTime Size


ExpiresActive on
ExpiresDefault "access plus 86400 seconds"

Mejorar la compatibilidad de los caracteres

Esta opción es para aquellos que no utilizan un juego de caracteres standard reconocido por el servidor, con esta
medida evitamos mostrar el famoso error 500.

AddDefaultCharset utf-8

Crear URL amigables

Una URL amigable consiste en disfrazar una URL llena de parámetros para que quede más elegante y para
ayudar también a tener una mejor posición de la página en los buscadores.

Por ejemplo, carpeta/fichero.php?id=120&idioma=es es una URL no amigable, por lo que la transformaremos en


carpeta/fichero/120/es que es más elegante y ayuda al posicionamiento en los buscadores. Es una URL amigable.
Con el fichero .htaccess podemos realizar este disfraz para la URL.

Tenemos una carpeta en nuestra web que tiene un fichero al que se le pasan parámetros.

sudominio.com/carpeta/fichero.php?id=25

Entonces, dentro de esta carpeta crearemos un .htaccess con el siguiente código:

Options +FollowSymLinks
RewriteEngine on
RewriteRule carpeta/(.*)/(.*).php$ /carpeta/fichero.php?id=$1

En la última línea es donde se realiza el cambio.

(.*) será el parámetro que le pasaremos, $1.

(.*).php$ será el nombre del fichero para "decorar" la URL.

Una vez creado el .htaccess, en el enlace de nuestra web pondremos:

<a href="http://info.cdmon.com/carpeta/25/nombre-del-fichero.php"> Enlace al fichero 25</a>

5/6
Cómo utilizar .htaccess
http://info.cdmon.com

Por lo tanto, carpeta/25/nombre-del-fichero.php será lo mismo que /carpeta/fichero.php?id=25.

Proteger carpetas con .htpasswd

Cuando queremos proteger una carpeta o ficheros con un usuario y contraseña, podemos utilizar,  junto el
.htaccess, un .htpasswd.

Se necesita crear un fichero .htaccess y un .htpasswd.

En el fichero .htpasswd introducimos lo siguiente:

usuario:Jy.Wu9Uw3b99c

Donde "usuario" es el nombre del usuario que es necesario para validarse y Jy.Wu9Uw3b99c es la contraseña
encriptada.

Para crear contraseñas encriptadas puede acceder al siguiente enlace donde puede crear el código que necesita
en su .htpasswd.

https://www.cdmon.com/webapps/

Una vez tenga el .htpasswd con el código correcto, se debe crear un fichero .htaccess con el siguiente código:

AuthUserFile /ruta/absoluta/hacia/.htpasswd
AuthName "Necesita validarse"
AuthType Basic
require user usuario

Donde en AuthUserFile es la ruta entera de donde se encuentra el .htpasswd, AuthName es el mensaje que
aparecerá en la ventana donde le solicita el usuario y la contraseña, y require user es el nombre del usuario a
introducir.

6/6

También podría gustarte