Crwcion de captcha con php

Solo disponible en BuenasTareas
  • Páginas : 11 (2662 palabras )
  • Descarga(s) : 0
  • Publicado : 13 de septiembre de 2010
Leer documento completo
Vista previa del texto
Captcha es una palabra aleatoria y en ocasiones distorsionada mostrada como imagen que se utiliza para evitar que los robots accedan a determinadas web. Este tipo de verificación es utilizada por los programadores para evitar el spam en lo blogs por ejemplo.

La idea básica para crear un Captcha es generar primero un texto aleatorio, luego basado en este texto generamos una imagen la cual semuestra al usuario, finalmente se compara el texto ingresado por el usuario con lapalabra aleatorio generada.
Generar el Captcha
La primero es crear una imagen con un texto aleatorio, para ello un archivo llamado captcha.php el cual creará dinámicamente el texto. Para ello creamos una función llamada randomText que se encarga de generar una cadena de texto aleatorio, acepta un parámetro el cualle indica cuantos caracteres puede tener el texto generado.
1. // archivo: captcha.php
2. function randomText($length) {
3.     $pattern = "1234567890abcdefghijklmnopqrstuvwxyz";
4.     for($i=0;$i<$length;$i++) {
5.       $key .= $pattern{rand(0,35)};
6.     }
7.     return $key;
8. }
Lo siguiente es crear una variable de sesión para guardar el texto generado,luego de ello tomamos una imagen que contiene el fondo para el captcha en nuestro caso la imagen es bgcaptcha.gif, luego creamos el texto sobre esta imagen para luego mostrarla en el navegador como imagen enviándole un header indicando el tipo de archivo.
1. session_start();
2. $_SESSION['tmptxt'] = randomText(8);
3. $captcha = imagecreatefromgif("bgcaptcha.gif");
4. $colText =imagecolorallocate($captcha, 0, 0, 0);
5. imagestring($captcha, 5, 16, 7, $_SESSION['tmptxt'], $colText);
6. header("Content-type: image/gif");
7. imagegif($captcha);
Crear el formulario para verificar el Captcha
Lo siguiente es mostrar la imagen generado para que el usuario pueda leerlo e ingresar el texto en el formulario para ser verificado. Naturalmente esta verificación será partede un formulario mucho mas grande pero solo incluimos un campo para propósitos de ejemplo. Esto lo incluimos en elarchivo captchademo.php, note que al incluir la imagen hemos colocado la ruta al php que genera la imagen.
1. Ingresar el texto mostrado en la imagen <br>
2. <form action="captchademo.php" method="post">
3.   <img src="captcha.php" width="100"height="30"><br>
4.   <input name="tmptxt" type="text"><br>
5.   <input name="btget" type="submit" value="Verificar Codigo">
6.   <input name="action" type="hidden" value="checkdata">
7. </form>
Verificar el texto Ingresado
Lo siguiente es verificar el texto ingresado en el formulario y compararlo con la variable $_SESSION['tmptxt'] que contiene el textogenerado aleatoriamente. Para ello verificamos que se haya enviado el formulario y luego comparamos el texto ingresado con el texto que tenemos en la variable de sesión.
1. session_start();
2. if ($_POST['action'] == "checkdata") {
3.     if ($_SESSION['tmptxt'] == $_POST['tmptxt']) {
4.         echo "Bienvenido";
5.     } else {
6.         echo "Inténtalo nuevamente";
7.    }
8.     exit;
9. }
Ideas Adicionales
Nuestro ejemplo es sencillo, pero se puede mejorar esto por ejemplo dibujando lineas aleatorios con ángulos aleatorios sobre el texto, también se puede dibujar el texto con una inclinación aleatorio, también se pueden colocar cada letra con distintos ángulos de rotación y color. Con estos adicionales pueden lograr un Captcha mucho masconsistente y seguro.
Pueden ver el ejemplo funcionando en captchademo.php y también pueden descargar los archivos con las fuentes para que lo descarguen y prueben.

miércoles 30 de septiembre de 2009
Interfaces CRUD para Mantenimiento de Bases de Datos (I)
Luego de terminar un ciclo de locos y de aprobar todos mis cursos, por fin hoy puedo publicar una entrada en este blog, continuando con el...
tracking img