Diferencia entre revisiones de «Ejemplo de reCAPTCHA en KumbiaPHP»
De KumbiaPHP Framework Wiki
m |
|||
Línea 71: | Línea 71: | ||
<source lang=php > | <source lang=php > | ||
− | < | + | <strong>Rellena el cuadro con tu nombre: </strong> |
<?php | <?php | ||
echo form_tag('captcha/comprobar'); | echo form_tag('captcha/comprobar'); |
Revisión del 12:00 10 may 2010
{{#if:
|}}
{{#if:
|}}Este Artículo cumple con todos los quererimientos de los Kumbieros. |
{{{imageright}}} |
Nota previa Este ejemplo esta sacado de la documentacion de reCAPTCHA y adaptado a un controlador/vista de KumbiaPHP de forma básica. Se puede mejorar creando un helper, pero queda fuera del ejemplo :)
- Descargar la libreria reCAPTCHA, descomprimela y copia el fichero recaptchalib.php en /app/libs de tu arbol de directorios de KumbiaPHP.
- Si no lo has hecho ya, registrate y solicita una key de API en la web de reCAPTCHA.
- Crea el fichero recaptcha.php en app/libs/ con el siguiente contenido, sustituyendo X e Y por tus API Key obtenidas.
<?php
include ("recaptchalib.php");
$publickey = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
$privatekey = "YYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYYY";
?>
- Ahora creamos un controlador para el captcha:
<?php
// Incluimos el fichero con la libreria y nuestra API Key
require_once APP_PATH. '/libs/recaptcha.php';
class CaptchaController extends ApplicationController {
public function index() {
// Generamos el reCAPTCHA
$this->Captcha = recaptcha_get_html($publickey);
}
public function comprobar() {
// Comprobamos que se haya rellenado el reCAPTCHA
if ($_POST["recaptcha_response_field"]) {
// Realizamos la comprobacion
$resp = recaptcha_check_answer ($privatekey,
$_SERVER['REMOTE_ADDR'],
$_POST['recaptcha_challenge_field'],
$_POST['recaptcha_response_field']);
if ($resp->is_valid) {
// Aqui seguría nuestra comprobacion del resto de los
// datos del formulario
echo "You got it!"; die;
} else {
// Capturamos el error para mostrarlo
$error = $resp->error;
}
}
// Si vienen datos de formulario, los enviamos a la vista de nuevo
if ($this->has_post('Datos')) $this->Datos = $this->post('Datos');
// Generamos un nuevo reCAPTCHA con el codigo de error obtenido
$this->Captcha = recaptcha_get_html($publickey, $error);
// Mostramos la misma vista que en el index
$this->render('index');
}
}
?>
- Por último, creamos la vista:
<strong>Rellena el cuadro con tu nombre: </strong>
<?php
echo form_tag('captcha/comprobar');
echo input_field_tag('DatosForm.nombre');
echo $Captcha;
echo submit_tag('Enviar datos');
?>
- Ya esta! Ahora ya puedes visitar la URL de tu controlador en http://<tuhost>/captcha y probarlo.
Saludos, Soukron