Este sitio utiliza cookies propias y de terceros. Si continúa navegando consideramos que acepta el uso de cookies. OK Más Información.

Cómo crear URLS amigables con .htaccess

  • 1 Respuestas
  • 2694 Vistas

0 Usuarios y 1 Visitante están viendo este tema.

Conectado ANTRAX

  • *
  • Administrator
  • Mensajes: 5609
  • Actividad:
    100%
  • País: ar
  • Reputación 37
  • ANTRAX
    • Ver Perfil
    • Underc0de
    • Email
  • Skype: underc0de.org
  • Twitter: @Underc0de
« en: Enero 04, 2013, 10:04:31 am »
¿Qué es una URL amigable? Lo mejor es un ejemplo. Esto NO es una URL amigable:


En cambio esta SI es una URL amigable:


Su propio nombre lo indica: las URL amigables son más fáciles de usar y de recordar por los usuarios y también se dice (y hay quien dice que no) que son mejores para el posicionamiento en buscadores. Además describen mucho mejor los enlaces dentro de una página web y añade un mayor nivel de profesionalidad a nuestras webs.

De todas formas, cuando hemos creado una página dinámica en PHP lo normal es que tengamos URL no amigables. ¿Cómo las convertimos en amigables de manera automática? Una manera de hacerlo es con un archivo .htaccess y gracias a Apache y su mod_rewrite.

Veamos la teoría: mod_rewrite es un módulo de Apache que permite manipular en el servidor las URLs solicitadas. Es decir, cuando llega al servidor la solicitud de una URL, esta se comprueba con respecto a una serie de reglas creadas con Expresiones Regulares creadas para detectar un patrón determinado. Si se encuentra ese patrón en el URL y se cumple la condición impuesta por la Expresión Regular se sustituye el patrón por una cadena de texto o por una acción determinada


IMPORTANTE: Para que todo esto funcione tiene que estar activado el módulo mod_rewrite en nuestro servidor Apache. Podemos saber si lo está simplemente con:

Código: PHP
  1. <?php phpinfo(); ?>

Y de entre toda la información recibida si el módulo está activado tendremos:


Lo más normal es que esté activado. Sino fuera así quizás tendríamos que hablar con nuestro proveedor de hosting.

Una vez sabemos que mod_rewrite está activado lo que necesitamos es un archivo .htaccess ¿Qué es un archivo .htaccess? Es un fichero de configuración utilizado por los servidores web Apache. Son archivos de texto.

¿Qué vamos a escribir en el archivo .htaccess? Como decíamos antes, una serie de Expresiones Regulares para interpretar el URL entrante y crear un URL saliente interpretable por nuestro código. Si no sabéis nada sobre Expresiones Regulares (o Regular Expressions en Inglés) es importante que leais algo sobre las mismas antes de seguir. Con una simple búsqueda en Google podréis encontrar gran cantidad de tutoriales. Si sabéis inglés, este tutorial de themeforest es muy bueno. También podéis bajaros esta hoja de referencia de Expresiones Regulares (en inglés)

http://www.addedbytes.com/download/regular-expressions-cheat-sheet-v2/png

Bueno, vamos a pasar a la acción. Os aconsejo que lo hagáis también vosotros improvisando casos distintos para poderlo comprender mejor. Vamos a empezar por un ejemplo sencillo: Vamos a crear dos archivos, uno index.php y otro clientes.php

index.php tendrá únicamente un enlace a clientes.php, para simplificarlo todo un poco.

Código: HTML5
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  2.   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" lang="es" xml:lang="es">
  4.     <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
  5.     <title>Ejemplo de URL amigable</title>
  6. </head>
  7.   <h1>Ahora estás en index.php</h1>
  8.   <a href="clientes/juan">Juan</a>
  9. </body>
  10. </html>

Como podéis ver el enlace es ya una URL amigable. Sin embargo al hacer click sobre el enlace necesitamos interpretar esa URL que llega al servidor para que este sepa qué hacer. Creamos un archivo de texto, lo grabamos como .htaccess y escribimos en él:

Código: HTML5
  1. # Activar RewriteEngine
  2. RewriteEngine on
  3.  
  4. # Reescribir la URL solicitada por el usuario
  5. #   Entrada:  clientes/NOMBRE/
  6. #   Salida: clientes.php?id=NOMBRE
  7. RewriteRule ^clientes/(\w+)/?$ clientes.php?id=$1

Vamos a ver línea a línea. En primer lugar tenemos que activar la re-escritura de la URL, para lo cual hay que activar RewriteEngine. A continuación establecemos una Regla de Re-escritura (RewriteRule) para gestionar la página clientes.php. Como véis, estamos re-escribiendo la URL amigable clientes/juan al formato normal clients.php?id=’juan’
En esta regla de re-escritura hay dos partes. Por un lado ^clientes/(\w+)/?$ que es una expresión regular que indica:


Ahora vamos con la segunda parte. En la segunda parte tenemos la expresión que sustituirá a la primera parte:


Ahora vamos a ver el archivo clientes.php:

Código: PHP
  1. <?php
  2. // Obtenemos el nombre del usuario desde la URL
  3. $id = $_GET['id'];
  4. ?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  5.    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  6. <html xmlns="http://www.w3.org/1999/xhtml" lang="es" xml:lang="es">
  7. <head>
  8.     <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
  9.     <title>Ejemplo de URL amigable</title>
  10. </head>
  11. <body>
  12.   <h1>Ahora estás en clientes.php</h1>
  13.   <p>Nombre del cliente: <?php echo $id; ?></p>
  14. </body>
  15. </html>

Haced la prueba y veréis cómo funciona perfectamente la URL amigable. Para complicar más las cosas se pueden incluir banderas al final que cada expresión. Imaginaros por ejemplo que hubiera posibles alternativas para reescribir una URL amigable, pero queremos que una vez encuentre la primera se detenga ahí y no siga contrastándose con el resto de Expresiones Regulares. Entonces la bandera a añadir sería [L]:

Código: Text
  1. RewriteRule ^([a-zA-Z0-9-]*)/([0-9]+)\-([a-zA-Z0-9-]*)\.html(.*)$ product.php?id_product=$2$4 [L]
  2. RewriteRule ^([0-9]+)\-([a-zA-Z0-9-]*)\.html(.*)$ product.php?id_product=$1$3 [L]

Tenéis todas las banderas en esta hoja de ayuda rápida de mod_rewrite.

http://www.addedbytes.com/cheat-sheets/mod_rewrite-cheat-sheet/

Por último, decir que es aconsejable añadir unas pocas líneas más a nuestro código. Lo voy a hacer aprovechando para crear un nuevo ejemplo. Supongamos un caso como este:


El archivo .htaccess que crearíamos sería:

Código: Text
  1. <IfModule mod_rewrite.c>
  2. # Activar RewriteEngine
  3. RewriteEngine on
  4. RewriteBase /
  5. RewriteCond %{SCRIPT_FILENAME} !-d
  6. RewriteCond %{SCRIPT_FILENAME} !-f
  7. # Reescribir la URL solicitada por el usuario
  8. #   Entrada:  ID-NOMBRE
  9. #   Salida: pruducto.php?id=ID
  10. RewriteRule ^([0-9]+)\-([a-zA-Z0-9-]*)$ producto.php?id=$1
  11. </IfModule>

Hemos añadido un condicional:

Código: Text
  1. <IfModule mod_rewrite.c>
  2. </IfModule>

para comprobar que está activado el módulo antes de hacer nada. Luego hemos añadido “RewriteBase /” que indica que el directorio base es el raíz. Si fuera por ejemplo una carpeta llamada “base” haríamos “RewriteBase /base”.
Además hemos añadido dos líneas que lo que hacen es restringir la re-escritura sólo a rutas que no existan previamente. Es decir, que no valdría por ejemplo para ejemplo.com/imagenes/logo.png. La primera línea previene los directorios que ya existan con la bandera !-d y la segunda hace que se ignoren ficheros que ya existan con la bandera !-f.

Luego, en la regla de reescritura, tenemos una entrada compuesta por números, luego va un guión (/-) y luego una cadena que puede incluir letras en mayúsculas, en minúsculas, números y guiones (por lo que 34-lampara-verde cumpliría). La salida que ya conoce nuestro código PHP (aunque esto está oculto al usuario) es producto.php?id=$1, siendo $1 el valor que hemos atrapado entre los dos primeros paréntesis (en este caso, 34). Si observáis tenemos también atrapado un segundo grupo que es ([a-zA-Z0-9-]*) y que lo podríamos recuperar con $2, pero en este caso no nos sirve.

Esto es sólo el comienzo, pero toda la base está ahí. Otra manera alternativa de conseguir URL amigables es combinar un archivo .htaccess con PHP, pero eso sería materia de otro artículo. Algunas de las lecturas recomendadas a continuación sí indican cómo hacerlo.

Fuente: http://www.emenia.es/como-crear-urls-amigables-con-htaccess/


Desconectado sr.mcbecker

  • *
  • Underc0der
  • Mensajes: 14
  • Actividad:
    0%
  • Reputación 0
    • Ver Perfil
    • *sinrevelar!
    • Email
« Respuesta #1 en: Enero 04, 2013, 10:33:28 am »
Gracias por el tutorial antrax me pongo a intentar hacer funcionar la url amigable!
Tengo algo muy gordo entre manos!

 

¿Te gustó el post? COMPARTILO!



Como reparar tu PC (paso a paso) con CD

Iniciado por martinanonymo

Respuestas: 0
Vistas: 1922
Último mensaje Febrero 06, 2013, 10:07:50 am
por martinanonymo
Curso Multimedia Tutellus – Como Conseguir Trabajar desde Casa en Internet

Iniciado por larson32

Respuestas: 1
Vistas: 3448
Último mensaje Octubre 01, 2018, 01:22:23 pm
por Hacker fashion
[LIBRO] HACKING ÉTICO: cómo hackear profesionalmente en 21 días

Iniciado por graphixx

Respuestas: 0
Vistas: 3037
Último mensaje Septiembre 21, 2015, 10:59:32 pm
por graphixx
[PDF] Web Hacking 101 en Español - Cómo hacer dinero hackeando éticamente

Iniciado por graphixx

Respuestas: 0
Vistas: 6781
Último mensaje Abril 29, 2017, 12:14:35 am
por graphixx
¿Quieres conocer como funciona windows por dentro?

Iniciado por D3ivid

Respuestas: 3
Vistas: 3216
Último mensaje Julio 03, 2015, 03:39:13 pm
por DaRK UnLiMiTeD