INSTALANDO EL ENTORNO
Instalación del servidor web
Instalación de postgreSQL y pgAdmin
Instalación IDE Eclipse
Instalación de Filezilla
INDICE
Introducción
Patrón MVC
Configuración del framework
Conceptos sobre cakePHP
Desarrollo con scaffold
Ejemplo Completo
Añadir funcionalidad
Diseño de la aplicación
INTRODUCCION
CakePHP es un framework para programar aplicaciones Web que sigue la arquitectura MVC
(Modelo Vista Controlador: http://es.wikipedia.org/wiki/MVC).
Para su funcionamiento requiere un servidor Web Apache, con PHP (versión 4 o 5
preferentemente) y un servidor de base de datos postgreSQL (aunque también trabaja con
‘MySQL’, ‘SQLite’ o ‘Firebird’).
Existen herramientas, como XAMPP (http://www.apachefriends.org/en/xampp.html), que
integran ambos servicios en una única instalación.
El presente tutorial se ha realizado con las versiones 2.2.14 de Apache, 5.3 PHP y 8.4 de
postgreSQL.
La versión de cakePHP con la que se ha trabajado y cuyo funcionamiento se va a describir
es la 1.3.6.
Esta herramienta se puede descargar de su web oficial: http://www.cakephp.org
Los lectores de este tutorial deberán tener conocimientos de POO en PHP, gestión de
postgreSQL y conceptos teóricos de bases de datos
PATRON MVC
Modelo Vista Controlador (MVC) es un patrón de arquitectura de software que separa los
datos de una aplicación, la interfaz de usuario, y la lógica de control en tres
componentes distintos.
El patrón MVC se ve frecuentemente en aplicaciones web, donde la vista es la página
(X)HTML y el código que provee de datos dinámicos a la página.
Modelo: la lógica de la aplicación además del acceso a datos (SQL, LDAP, XML,
ActiveRecord, ORM) e integridad de la información.
Vista: la interfaz para el usuario más frecuentemente, (X)HTML para los navegadores
Controlador: recibe el input del usuario (generalmente un link o un formulario ) y lo pasa,
a veces al Modelo
VENTAJAS
Son muchas las ventajas del patrón MVC:
Solidez
Diseño
Coherencia
Modularidad
pero quizás las más importante es que hace mucho más fácil el mantenimiento y la
cooperación entre varios desarrolladores
PRINCIPIOS BASICOS
Extensiones de controladores (components)
beforeFilter() se ejecuta antes de cualquier otra acción del controlador
beforeRender() se ejecuta despues de la lógica del controlador pero antes de que se renderice
la vista
Extensiones de vistas (helpers)
El ayudante helper es una clase que ayuda a la lógica de una vista. Del mismo modo que
varios controladores utilizan un componente, los helpers hacen que varias vistas accedan y
compartan logica presentacional.
Extensiones de Modelos (behaivors)
Así como los controladores, los modelos tambien incluyen callbacks:
beforeFind()
afterFind()
beforeValidate()
beforeSave()
afterSave()
beforeDelete()
afterDelete()
ESTRUCTURA DE ARCHIVOS
Estos serán los ficheros y carpetas que deberías ver:
app
cake
plugins
vendors
.htaccess
index.php
README
Observarás 3 carpetas principales:
La carpeta app será donde haremos nuestra magia: es donde se ubicarán los ficheros de
tu aplicación.
La carpeta cake es donde nosotros hemos hecho nuestra magia. Comprométete a no
modificar los ficheros de esta carpeta. No podremos ayudarte si has modificado el núcleo.
Finalmente, la carpeta vendors es donde ubicarás las librerías PHP de terceros que
necesites usar con tus aplicaciones en CakePHP.
ESTRUCTURA DE ARCHIVOS
La carpeta app de CakePHP es donde realizarás la mayor parte del desarrollo de tu aplicación.
Contiene los (pocos) archivos de configuración que usa CakePHP. Detalles de conexión a bases de datos,
config
arranque (bootstrapping), archivos de configuración del núcleo y demás deberían ser almacenados aquí.
controllers Contiene los controladores de tu aplicación y sus componentes.
locale Almacena archivos de cadenas de texto para la internacionalización.
models Contiene los modelos de tu aplicación, comportamientos (behaviors) y orígenes de datos (datasources).
plugins Contiene los paquetes de plugins.
Aquí es donde CakePHP almacena datos temporales. La información que realmente se almacena depende de
cómo hayas configurado CakePHP, pero normalmente esta carpeta es usada para almacenar descripciones de
tmp modelos, registros (logs) y algunas veces información de sesiones.
Asegúrate de que esta carpeta existe y tiene permisos de escritura, ya que de lo contrario el rendimiento de tu
aplicación se verá muy afectado. En modo debug CakePHP te avisará si este no es el caso.
Cualesquiera clases o librerías de terceros deberían ser ubicadas aquí. Hacerlo así hace que sea más fácil de
acceder a ellas usando la función App::Import('vendor','nombre'). Los observadores meticulosos notarán que esto
vendors parece redundante, ya que también existe una carpeta vendors en el nivel superior de nuestra estructura de
directorios. Veremos las diferencias entre las dos cuando discutamos acerca de la administración de múltiples
aplicaciones y configuraciones de sistemas más complejos.
Los archivos de presentación son ubicados aquí: elementos (elements), páginas de error, ayudantes (helpers),
views
layouts y archivos de vistas.
En una configuración de producción, esta carpeta debería servir como la raíz del sitio (document root) para tu
webroot aplicación. Las carpetas aquí también sirven como lugares de almacenamiento para hojas de estilo en cascada
(CSS stylesheets), imágenes y archivos JavaScript.
CONVENCIONES
Con las convenciones de CakePHP, podrás ahorrar tiempo en la marcha obteniendo libre
funcionalidad, y también se libera de la pesadilla del mantenimiento del seguimiento de los
archivos de configuración.
Las convenciones también hacen un sistema de desarrollo muy uniforme, permitiendo a
otros desarrolladores ayudar más fácilmente.
CONVENCIONES PARA NOMBRES
DE ARCHIVOS Y CLASES
En general, los nombres de archivo llevan el símbolo underscore "_", mientras que los
nombres de las clases usan CamelCase. La clase MyNiftyClass puede ser encontrada
en el archivo my_nifty_class.php, por ejemplo.
Otro ejemplo, el nombre de la clase que contiene un archivo puede no necesariamente
ser encontrada en el nombre de archivo.
La clase EmailComponent es encontrada en un archivo llamado email.php, y la clase
HtmlHelper es encontrada en un archivo llamado html.php
… CONVENCIONES DE MODELOS Y
BASE DE DATOS
Los nombres de las clases de modelos están en singular y en formato CamelCase.
Persona, PersonaGrande, y PersonaMuyGrande son todos ejemplos de nombres de
modelos convencionales.
Los nombres de las tablas correspondientes a modelos de CakePHP están en plural y
usando guión bajo.
Las tablas subyacentes para los modelos arriba mencionados serían: personas,
personas_grandes, y personas_muy_grandes respectivamente.
CONVENCIONES DE MODELOS Y
BASE DE DATOS
Los nombres de los campos con dos o más palabras se definen con guiones bajos:
nombre_y_apellidos.
El nombre por defecto de las claves foráneas en relaciones hasMany, belongsTo o
hasOne, es el nombre de la tabla relacionada (en singular) seguido de _id.
Así, si Panadero hasMany Tarta, la tabla tartas referenciará la tabla panaderos mediante la
clave foránea panadero_id. Para una tabla compuesta por varias palabras como
tipos_categorias, la clave foránea sería tipo_categoria_id.
CONVENCIONES DE CONTROLADORES
Los nombres de las clases de los controladores son en plural, con formato CamelCased,
y terminan en Controller.
PersonasController y UltimosArticulosController son ejemplos de nombres
convencionales de controladores.
El primer método que escribas para un controlador debe de ser el método index().
Cuando la petición especifica un controlador pero no una acción, el comportamiento por
defecto de CakePHP es ejecutar el método index() de dicho controlador.
Por ejemplo, una petición de http://www.example.com/apples/ se corresponde con la
llamada al método index() del controlador ApplesController, mientras que
http://www.example.com/apples/view se corresponde con una llamada al método view()
del controlador ApplesController.
CONVENCIONES DE VISTAS
Los archivos de plantillas de Vistas (Views) deben ser nombradas después de las
funciones de los controladores con guión bajo "_".
La funcion getReady() del controlador PeopleController se visualizara con la plantilla de
vista en /app/views/people/get_ready.ctp por ejemplo.
El patrón básico es: /app/views/controller/underscored_function_name.ctp
… CONVENCIONES DE VISTAS
Al nombrar las piezas de su aplicación utilizando las convenciones de CakePHP, se adquiere
funcionalidad sin mucho mantenimiento de la configuración.
Ejemplo final de las convenciones
Tabla de Base de Datos: ‘people’
Clase de Modelo: ‘Person’, encontrada en /app/models/person.php
Clase de Controlador: ‘PeopleController’, encontrada en
/app/controllers/people_controller.php
Plantilla de Vista, encontrada en /app/views/people/index.ctp
Usando estas convenciones, CakePHP entiende que la peticion http://example.com/people/
apunta a la llamada de funcion index() en el controlador PeopleController, donde el modelo
Person esta disponible automáticamente (y apunta automáticamente a la tabla ‘people’ en la
base de datos), y se renderiza en el archivo.