symfony2 formacion y primeros pasos

Post on 20-Jun-2015

503 Views

Category:

Software

1 Downloads

Preview:

Click to see full reader

DESCRIPTION

Documento Formativo de Symfony2 en el que explica desde qué es Symfony hasta los primeros pasos básicos: instalación, configuración, entidades, Twig, YAML...

TRANSCRIPT

Symfony 2

Formación y primeros pasos

Por: Sonia Benítez MartínezWeb Developer@Neithar

Índice I● Introducción a Symfony● Características● Recordando MVC y ORM● Twig● YML● Gestionando dependencias con Composer● Instalando Composer (Windows)● Instalando Composer (Linux)● Descargando Symfony2(Windows)● Descargando Symfony2(Linux)

Índice II● Consideraciones● Estructura del proyecto● Controladores Frontales● Entornos● Caché● Profiler● Mensajes de Error● Aplicando la filosofía de Symfony● Entidades● ¿Qué son los Bundles?

Índice III● Bundles en Symfony● El comando Console● Crear un Bundle● Creando el Esquema● La Base de Datos● El enrutador (Routing Component)● La cara oculta del Routing● Rutas● Patrón de nomenclatura para controladores● Comandos Útiles● Bibliografía

Introducción a Symfony● Symfony es un Framework PHP desarrollado en PHP 5.3● Arquitectura MVC

● Creado por la comunidad liderada por Fabien Potencier ● Integra Frameworks como:

o Doctrineo Twig

● Modelo: Doctrine, ORM basado en Hibernate● Configuraciones en:

o YAML, XML, PHP

Características● Open-source● Muy flexible● Extensible● Completo● Rápido● Alto rendimiento● Gran comunidad y documentación multiidioma● Basado en buenas prácticas

Recordando MVC (Modelo - Vista- Controlador)

● Vista: Visualización de la información, diseño, colores, estilos

● Modelado: Capa que se responsabiliza de la manipulación de los datos

● Controlador: Intermediario entre los dos anteriores: Procesa y muestra los datos obtenidos por el Modelo.

ORM (Object-Relational Mapping)

● Doctrine:o Framework para tratar con BBDDo Conexióno Generación SQLo Manipulación datoso Transaccioneso Desconexión

Twig I

o Motor y lenguaje de plantillas para PHP utilizado por defecto en Symfony2 Una plantilla es un archivo de texto que puede ser generado en

el formato que se necesite (HTML, CSS, XML, ...)o Rápido: Twig minimiza la cantidad de código necesaria para producir

el mismo efecto que con PHP puro.o Seguro: Twig sólo afecta a la construcción del template, no a la lógica

de negocio, impidiendo la mala gestión de datos o errores.o Flexible: Permite al desarrollador definir sus propias etiquetas y

filtros personalizados.o Sistema de herencia de plantillas y cacheo de plantillas

Twig II

o PHP es el mismo motor de templates (muy largo de escribir).

o Ejemplo:<?php echo htmlspecialchars($var, ENT_QUOTES, ‘UTF-8’); ?>

o Ésto en Twig:{{ var|e }}

¿Por qué otro motor de templates?

Twig III : Sintaxis orientada a Templates

o Hay muchos accesos directos (Shortcuts) para realizar acciones más comunes.

o Un ejemplo de iteración sobre un array:

{% for user in users %}

{{ user.name }}

{% else %}

No users have been found.

{% endfor %}

Twig IV : Algunas Funcionalidades

o Con Twig hay todas las opciones posibles a la hora de crear templates: existe herencia múltiple, bloques de código, escape automático, entre muchas otras funcionalidades:

o Ejemplos:{% extends “MDWDemoBundle:Default:index.html.twig” %}

{% block content %}

Content of the page…

{% endblock %}

Twig V : Un poco de sintaxis

● Comentarios {# Comentario #}→

● Imprimir {{ mostrar_algo }} <?php echo $mostrar_algo; ?> → →

● Tags {% hacer_algo %} {% if online == false %} → →

<p> Mainentance! </p>

{% endif %}

● Filtros {{ ‘my first car’|capitalize }} →

● Funciones {{ random(5) }}→

● Tests {# Se evalúa a true si la variable es null, false o cadena vacía #}→

{% if foo is empty %} … {% endif %}

YAML I

● Lenguaje muy sencillo que permite describir los datos como en XML, pero en una sintaxis mucho más sencilla.

● Presenta un formato especialmente útil para describir datos que pueden ser transformados en arrays simples y asociativos.

● Ejemplo:

o $casa = array(‘familia’ => array(‘apellido’ => ‘García’, ‘padres’ => array(‘Antonio, María’), ‘hijos’ => array(‘Jose’, Manuel, Carmen)), dirección => array(‘numero’ => 34, ‘calle’ => ‘Gran Via’, ‘ciudad’ => ‘Barcelona’, ‘codigopostal’ => ‘12345’ ) );

YAML II

Gestionando dependencias con Composer

Vale, pero… ¿Qué es composer?

● Composer es un Gestor de Dependencias PHP● Contiene una BBDD online de librerías de terceros● La BBDD se centraliza en el repositorio Packagist● 1 único archivo de config descarga n librerías→● Ǝ Librerías como: Symfony, Wordpress, Drupal, etc.

Instalando Composer (W) IPartiendo de: Xampp / Wampp OK →

1. Descargar composer: https://getcomposer.org/installer2. Guardar como instalador.php en ruta donde crearemos los proyectos Symfony2 (Ej:

C:\www\)3. Abrir cmd, situarse sobre ruta (C:\www\) y ejecutar: php instalador.php

Instalando Composer (W) II3.1. Si no va: Añadir al final del path de variables del sistema (equipo botón derecho →propiedades configuración avanzada del sistema variables de entorno path → → → →añadir al final: ;C:\xampp\php; 4. Una vez hecho el paso 3, ya tendremos composer instalado:

Instalando Composer (W) III5. Para poder ejecutar composer desde varios sitios moverlo a xampp/php →6. También crear en xampp/php un fichero composer.bat que contenga:

@ECHO OFF php "%~dp0composer.phar" %*

7. Para actualizar composer: Ejecutar en consola: composer self-update

Instalando Composer (L) IPartiendo de: LAMP OK →

1. Abrir consola de comandos y acceder al directorio raíz del proyecto Sf22. Ejecutar el comando:

$ curl -s https://getcomposer.org/installer | php3. Si todo ha ido bien, en el directorio raíz del proyecto Sf2 aparecerá un archivo

llamado composer.phar. Para comprobar que se ha instalado correctamente, ejecuta el siguiente comando que muestra el menú de opciones de Composer:$ php composer.phar

4. Instalar Composer de esta manera es correcto, pero obliga a realizar una nueva instalación para cada proyecto Symfony2. Si tienes muchos proyectos, es mucho mejor que instales Composer de forma global en tu ordenador, para que todos los proyectos utilicen la misma versión de Composer.

Instalando Composer (L) II5. Para instalar Composer globalmente, mover el archivo composer.phar a algún directorio ejecutable del sistema, como por ejemplo:

$ sudo mv composer.phar /usr/local/bin/composer

6. Comprobar que todo funciona bien ejecutando el comando composer sin opciones desde cualquier directorio del sistema.

7. La instalación global de Composer también facilita su mantenimiento, ya que sólo hay que ejecutar el siguiente comando para actualizar la versión de Composer de todos los proyectos:

$ sudo composer self-update

Descargando Symfony 2 (W)● Si no tienes Git ¡Instálalo! (→ http://msysgit.github.io/)● Si ya tienes Git ¡Vamos!→

Para instalar Symfony 2 en consola ejecutaremos el comando:php composer.phar create-project symfony/framework-standard-edition C:/www/nombreProyecto/ 2.5.0

1. composer: Para ejecutar las funcionalidades de composer2. create-project:Ésta funcionalidad le dice a composer que cree un nuevo proyecto3. symfony/framework-standard-edition:Con ésto especificamos a composer que queremos

instalar la versión standar edition de Symfony del packagist4. path/: Ruta donde se tiene que instalar el proyecto5. 2.5.0: Versión de Symfony a instalar

Para comprobar si el equipo está preparado para ejecutar Symfony 2, una vez finalizado ejecutaremos el comando:php app/check.php

Descargando Symfony 2 (L) I● Si no tienes Git ¡Instálalo! (→ http://msysgit.github.io/)● Si ya tienes Git ¡Vamos!→

Para instalar Symfony 2 en consola ejecutaremos el comando:$ composer create-project symfony/framework-standard-edition <directorio> 2.5.0

1. composer: Para ejecutar las funcionalidades de composer2. create-project:Ésta funcionalidad le dice a composer que cree un nuevo proyecto3. symfony/framework-standard-edition:Con ésto especificamos a composer que queremos

instalar la versión standar edition de Symfony del packagist4. <directorio>: Ruta donde se tiene que instalar el proyecto5. 2.5.0: Versión de Symfony a instalar

Para comprobar si el equipo está preparado para ejecutar Symfony 2, ejecutaremos el comando:php app/check.php

Descargando Symfony 2 (L) IISi todo ha funcionado bien, Symfony 2 ya está instalado correctamente. Para comprobarlo, se debe ejecutar el siguiente comando de consola directamente en la raíz del directorio donde se ha instalado Symfony:

$ php app/console

La consola debería mostrar una lista muy larga con todos los comandos disponibles en las aplicaciones Symfony2.

Consideraciones I● Algunas configuraciones:

o php.ini: habilitar php_openssl.dll (extension=php_openssl.dll)o habilitar intl extensiono instalar acelerador PHP (APC)o los directorios app/cache y app/logs deben tener permisos de

escritura● Cambios en apache configurar virtualhost o cambiar en httpd.conf:→

o DocumentRoot “C:/www/nombreProyecto/web”o Directory “C:/www/nombreProyecto/web”

● Si todo ha ido bien...

Consideraciones II● Hasta que no se resuelvan los requerimientos obligatorios, no

podremos ingresar a:o http://localhost/nombreProyecto/web/app_dev.php

Y ver la pantalla de Bienvenida:

Estructura del Proyecto I● app\: Contiene la configuración de

todo el proyecto. Por lo general sólo existe una aplicación. El concepto de tener más de una aplicación en ésta versión se conoce como Bundle

● app\config\: Guarda todos los archivos de configuración de la aplicación

● app\cache\: Contiene todos los archivos generados por las numerosas cachés de Symfony2 (clases, enrutamiento, plantillas, entidades, validación, etc.). Junto con el directorio app\logs\ es el único en el que Symfony2 debe tener permisos de escritura.

Estructura del Proyecto II● app\logs\: Contiene archivos de log por la app (tanto dev, prod, test, etc.). Junto

con el directorio app\cache\ es el único en el que Symfony2 debe tener permisos de escritura.

● app\Resources\: Almacena recursos muy especiales (Como alguna librería Java) o recursos utilizados por el proyecto a nivel global (layouts de las plantillas)

● bin\: Dentro existe el script vendors.sh que se utiliza para actualizar el framework vía consola

● src\: Carpeta donde irá todo nuestro código. Residen los Bundles.● vendor\: Core del Framework y librerías de terceros● web\: Contendrá los archivos públicos del proyecto (js, css, etc). También se

encuentran los controladores frontales.

Controladores Frontales I● Un controlador frontal es un archivo mediante el que se accede a

una página.● Symfony maneja entornos, lo que indica:

o Mismas páginas Distintas configuraciones→● Entornos configurados por defecto:

o Desarrollo: http://localhost/nombreProyecto/web/app_dev.php

o Producción: http://localhost/nombreProyecto/web/app.phpo Test

Controladores Frontales II● Los archivos que no estén dentro de la carpeta web\ no pueden y no

deben ser accedidos por navegador.● Las páginas y programas de dentro la carpeta src\ no son directamente

accedidos por el navegador, sino a través de los controladores frontales.● Cualquier petición (request) que llegue a la aplicación para solicitar una

página específica debe ser sobre nuestros controladores y no directamente a ellas. Esto es debido a que los controladores frontales levantan todas la utilidades necesarias del Framework y luego invocan a la página solicitada.

Entornos● Desarrollo

o http://localhost/nombreProyecto/web/app_dev.php● Producción

o http://localhost/nombreProyecto/web/app.phpDiferencias:● Desarrollo: Configuración para Desarrollador● Producción: Optimizado para usuarios finales

Anotación:● En caso de que, al ingresar a la URL de producción y aparezca un error se

puede probar a eliminar el contenido de la carpeta app\cache\

Caché● Symfony pre-compila las páginas y las almacena en caché.● Los archivos se generan en PHP● Los archivos se guardan dentro de la carpeta app\cache

Para producción:● Una vez creados los archivos, las páginas son accedidas por caché

Para desarrollo:● La caché se genera por cada petición de las páginas para no tener que

estar borrándola constantementePara borrar la caché:● Eliminar el contenido de la carpeta app\cache

Profiler● Herramienta activa sólo para el entorno de desarrollo.● Proporciona información de cada petición como:

o Parámetros del Requesto Sentencias SQL ejecutadaso Tiempos transcurridoso Datos de sesióno etc.

Mensajes de Error I● Symfony mostrará más información de los errores en el entorno

de desarrollo que en producción.Ejemplo para página no existente:● En desarrollo: Aparecerá un StackTrace completo● En producción: Error 404

Mensajes de Error IIEntorno de desarrollo:

Aplicando la filosofía de Symfony

Antes de empezar a programar la aplicación se deben adaptar a Sf:● Funcionalidades● Wireframes o Mockups

● El orden recomendado para la filosofía de Symfony es:1. Definir las entidades2. Definir los bundles3. Enrutamiento

Entidades

● Ejemplo:

¿Qué son los Bundles?● Carpetas que contienen los archivos necesarios para un grupo de

funcionalidades específicas● “Paquetes” con una estructura definida, que puede contener

cualquier cosa e implementa una funcionalidad.● Permiten utilizar bundles de terceros y compartir los bundles

propios entre distintos proyectos

Bundles en Symfony I● Algunos de los bundles incluídos en la Standard Edition:

o Assetic: gestor de “assets” (CSS’s, JS, Imágenes, etc.) para PHP 5.3

o Doctrine: ORM (Object Relational Mapping)o Monolog: Sistema de logso SwiftMailer: Envío de mailso Twig: Lenguaje de plantillas

● Para ver los bundles existentes, ver en el fichero AppKernel.php dentro de la carpeta app\ del proyecto

Bundles en Symfony II● Una aplicación en Symfony2 podrá contener todos los bundles que se necesiten,

simplemente se deben crear y registrar. ● Todos los bundles deben ir dentro de la carpeta src\ del proyecto, mientras que los

Bundles de terceros deberán ir dentro de la carpeta vendor\.● Un Bundle tiene una estructura de carpetas y archivos definidos y un nombre

identificador dentro de nuestro proyecto que lo utilizaremos varias veces para hacer referencia al mismo.

● La versión estándar de Symfony2 viene ya con un Bundle de ejemplo llamado AcmeBundle y es el que se ejecuta al ingresar a http://localhost/Symfony/web/app_dev.php dando la bienvenida.

Bundles en Symfony III● Nosotros crearemos nuestro propio Bundle pero para esto haremos una pequeña

modificación en el archivo app\config\routing_dev.yml en donde buscaremos las siguientes líneas:

_welcome: pattern: / defaults: { _controller: AcmeDemoBundle:Welcome:index }

y las reemplazaremos por

_welcome: pattern: /bienvenida defaults: { _controller: AcmeDemoBundle:Welcome:index }

Bundles en Symfony IV● Con esto lo que se consigue es liberar la dirección:

http://localhost/Symfony/web/app_dev.php que corresponde a la bienvenida. ● Ahora para ingresar a esta página se debe escribir:

http://localhost/Symfony/web/app_dev.php/bienvenida en lugar de la anterior. ● Con ésto, se puede usar la dirección URL anterior para nuestro Bundle. Ahora

ingresando a la primera dirección debería dar un error 404 ya que no existe página asignada a esa ruta.

El comando console● Para poder crear un bundle se utilizará una utilidad de Symfony llamada “console”● Alguna funcionalidad de “console”:1. Abrir consola y entrar al directorio del proyecto2. Situarse sobre la carpeta del proyecto y ejecutar el siguiente comando:

a. php app\console --version3. Al ejecutar esto se nos mostrará un texto similar a: Symfony version 2.5.0 –

app/dev/debug4. El archivo app\console no es nada más que un script PHP que ejecuta varias tareas

(tasks) dependiendo de los parámetros que le pasemos (como por ejemplo el parámetro “–-version”).

5. Existen muchas tareas que Symfony puede hacer por nosotros. Para verlas todas simplemente puedes hacerlo ejecutando el script sin pasarle parámetros:

C:\www\MDW >php app\console

Crear un Bundle I1. Situarse sobre la ruta del proyecto y ejecutar el comando:

a. php app\console generate:bundle

2. Con este comando se ejecutará un generador que nos hará varias preguntas para

crear nuestro Bundle como se muestra a continuación:

Crear un Bundle II1. Namespace o carpeta contenedora del Bundle

formada por: Carpeta del proyecto\nombreBundle2. Identificador del Bundle. El sistema propone

entre corchetes la concatenación proyectoNombreBundle. Para aceptar enter→

3. Ubicación del bundle. Aceptar4. Formato de archivo que usará para las

configuraciones del Bundle. Propone [annotations] pero le diremos que queremos que sea “yml”.

5. ¿Generar estructura completa para el bundle?a. Sí, si se necesitab. No, por defecto

Crear un Bundle III6. Confirmamos si todo esta bien.

7. ¿Queremos registrar nuestro

Bundle en el archivo app\AppKernel.php? Sí→

8. ¿Queremos actualizar el archivo

app\config\routing.yml? Sí→

Crear un Bundle IV● Dentro de la carpeta src\ se crearía una carpeta

correspondiente a el nombre del proyecto y dentro nuestro Bundle con sus carpetas y archivos necesarios.

● El identificador del bundle sería, por ejemplo: “MDWDemoBundle”.

● En el archivo AppKernel.php si lo abrieramos, veríamos una línea que apuntaría al archivo MDWDemoBundle.php. Lo que hace es habilitarlo para el proyecto.

Crear un Bundle IV● Todo Bundle nuevo o de terceros que incluyamos al proyecto deben

ser registrados agregando la línea:

o $bundles = array( ... new MDW\ManualBundle\MDWDemoBundle(),);

● Por último también se agregarían las siguientes líneas al archivo app\config\routing.yml

o MDWDemoBundle:resource:

“@MDWDemoBundle/Resources/config/routing.yml"prefix: /

Creando el Esquema IRecordando el modelo de Ejemplo:

La Base de Datos

El enrutador (Routing Component) I

● Enrutandoo URL’s feas: index.php?article_id=27o URL’s bonitas: /leer/intro-a-symfony

● Flexibilidado Para cambiar la URL de una página /blog a

/noticias. ¿Cuántos enlaces necesitas actualizar para hacer el cambio? Con el enrutador de Symfony el cambio es sencillo.

El enrutador (Routing Component) II

● En acción:o Una ruta es un mapa desde un patrón URL hasta un

controlador.

El enrutador (Routing Component) III

El enrutador (Routing Component) IV

La cara oculta del Routing

Rutas ISymfony carga todas las rutas de la aplicación desde un archivo de configuración de enrutado: app/config/routing.yml

Rutas IIMuchas rutas pueden contener uno o más parámetros. Éstos pueden ser opcionales o no:

No opcional Opcional

Rutas IIILos requisitos de los parámetros son expresiones regulares, la complejidad y la flexibilidad de cada requisito depende de uno

Patrón de nomenclatura para controladores

paquete:controlador:acciónPor ejemplo, un valor _controller de AcmeBlogBundle:Blog:show

Comandos Útilescomposer update

php composer.phar require friendsofsymfony/user-bundle 1.3.4

php app/console cache:clear --env=dev

php app/console doctrine:schema:update --force

php app/console doctrine:generate:entities MWD/DemoBundle/Entity/EnityName --no-backup

php app/console doctrine:generate:entities MWD/DemoBundle/--no-backup

¡Eso es todo! ¡Muchas Gracias ^^

¿Os ha gustado? ¡¡Pues ahora a seguir practicando!!

Bibliografía I● http://www.slideshare.net/mario21ic/taller-introduccion-symfony2?related=1&utm_cam

paign=related&utm_medium=1&utm_source=1● http://www.slideshare.net/SymfonyZaragoza/crud-bsico-con-symfony-36780064?utm_cam

paign=ss_search&utm_medium=qf1&utm_source=27&qid=876ad1ac-5f7c-40c9-8910-88252825d243&v=qf1&b=&from_search=27

● http://www.slideshare.net/raulfraile/symfony2-framework-para-php5● http://www.maestrosdelweb.com/editorial/curso-symfony2-introduccion-instalacion● http://symfony.es/documentacion/● http://symfony.com/doc/current/book/doctrine.html● Routing:

http://www.slideshare.net/hydras_cs/clase-4-routing?qid=53f9a989-7cac-499e-af68-5010022ee87c&v=qf1&b=&from_search=5

Bibliografía III● APC:

o http://gregrickaby.com/the-perfect-apc-configuration/o http://dev.freshsite.pl/php-accelerators/apc.htmlo https://docs.moodle.org/22/en/Installing_APC_in_Windows

top related