Voy a explicaros una manera sencilla de hacer la paginación de vuestras webs y aplicaciones hechas con CakePHP en Ajax utilizando jQuery y un plugin para que el historial del navegador funcione correctamente.
Para mi ejemplo he utilizado CakePHP 1.3.3 y jQuery 1.4.2. El plugin que comentaba anteriormente se llama jQuery History Plugin y lo podéis descargar de gitHub.
Bien pues vamos a ello. Empecemos por el controlador. Simplemente tenéis que tener en cuenta que vamos a utilizar el helper de JavaScript, así que debemos activarlo:
Llegir més…
En este tutorial aprenderéis a gestionar los errores de CakePHP con y sin Ajax.
Lo primero de todo que tenéis que hacer es poner el debug a cero en vuestro fichero core.php, ya que con debug > 0 no funcionaría.
Ahora pasemos a crear (si no existe) el fichero /app/app_error.php con el siguiente contenido.
<?php // /app/app_error.php
class AppError extends ErrorHandler
{
function error404($params)
{
// Importamos RequestHandler para verificar si la conexión es mediante Ajax
App::import('Component', 'RequestHandler');
$this->RequestHandler = new RequestHandlerComponent();
if ($this->RequestHandler->isAjax())
{
// En caso de ser Ajax creamos la cabecera 404
$this->controller->header("HTTP/1.0 404 Not Found");
// y pasamos algunas variables a la vista que ahora crearemos
$this->controller->set('params', $params);
$this->controller->layout = 'ajax';
// Renderizamos la vista
$this->_outputMessage('ajax_error404');
}
// Aquí iría la gestión del error sin Ajax, en nuestro caso llamamos al método padre.
else parent::error404($params);
}
}
Pasemos a la creación de la vista… /app/views/errors/ajax_error404.ctp Llegir més…
Si habéis leído mi tutorial sobre la subida de ficheros con uploadify y validación Ajax en CakePHP recordaréis que separé los métodos add y ajax_add, ya que pensé que el único modo que había de mostrar un error de sesión al usuario era separando los métodos para, a uno de ellos darle permisos de acceso y al otro no.
De este modo podía mostrar un error de “sesión expirada” al usuario, así:
$user = $this->Auth->user();
if(!empty($user)){
// Código para añadir el elemento
}else{
$message = "<b>" . __("Error",true) . ":</b> " . __("Tu sesión ha expirado, vuelve a iniciarla por favor",true);
$data = $this->data;
$this->set('sessionTimeOut',compact('message','data'));
}
Llegir més…
Si queréis detectar las solicitudes AJAX mediante PHP podéis hacerlo mediante la variable HTTP_X_REQUESTED_WITH:
/* Verificamos si hay ajax */
if(!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
/* Contenido ajax */
}else{
/* Contenido normal */
}
Id con cuidado porque algunos servidores no proporcionan la variable HTTP_X_REQUESTED_WITH, así que haced alguna prueba antes de ir con toda la confianza a usarlo directamente en vuestra aplicación 😉
Ya hacía tiempo que tenía ganas de escribir una entrada “de estas” 😀 (de estas quiero decir de programación y con muuuucho muuuucho código, como a mí me gustan :P).
Hace unos meses conté cómo podíais utilizar el plugin Uploadify (de jQuery) para subir ficheros a vuestro portal hecho con CakePHP. Hoy iremos un poco más allá y crearemos un upload de imágenes con validación de campos con Ajax.
Antes de empezar estaría bien que hubierais leído el anterior tutorial —e incluso haberlo probado— para tener algo de práctica en el asunto. Este tutorial será (bastante) de ampliación del anterior. Quiero decir que habrá cosas en las que no profundizaré porque ya lo hice en el anterior, así como que en este hay mejoras, como la gestión de la respuesta de uploadify con JSON en lugar de con texto plano.
Si queréis podéis ver el resultado del tutorial que voy a explicar en este enlace:
Llegir més…