Diferencia entre revisiones de «Usuario:ManuelRomero/micursos/DWES/Tema1/Aplicaciones Web»

De WikiEducator
Saltar a: navegación, buscar
(Instalando Apache)
(Instalando Apache)
Línea 326: Línea 326:
 
<div class="slide">
 
<div class="slide">
 
===Instalando Apache===
 
===Instalando Apache===
[[Imagen:Apache.png]]
+
[[Imagen:Apache.png|center|200px]]
 
*Página oficial de apache http://httpd.apache.org/
 
*Página oficial de apache http://httpd.apache.org/
 
<source lang=bash>
 
<source lang=bash>
Línea 340: Línea 340:
 
#Fichero de configuracion
 
#Fichero de configuracion
 
#Sitio web por defecto
 
#Sitio web por defecto
#Directiva '''''DocumentRoot}}
+
#Directiva '''''DocumentRoot'''''
 +
#Directiva '''''ServerName'''''
 +
#Directiva '''''<Directory> ... </Directory>'''''}}
 
{{Actividad|
 
{{Actividad|
 
#Probamos a ver si responde nuestro servidor web
 
#Probamos a ver si responde nuestro servidor web
Línea 362: Línea 364:
 
*Es muy importante conocer la ubicación del fichero donde se identifican los errores según se producen por parte del servidor
 
*Es muy importante conocer la ubicación del fichero donde se identifican los errores según se producen por parte del servidor
 
*Muchas veces va a ser nuestro única forma de saber por qué algo está fallando
 
*Muchas veces va a ser nuestro única forma de saber por qué algo está fallando
 +
{{Puntos clave|
 +
*Fichero de errores '''''/var/log/apache/error.log'''''
 +
*Recuerda el comando '''''sudo tail -f error.log'''''(mantiene el fichero abierto y actualizado)}}
 +
*Existen otros modulos y extensiones de apache que ya instalaremos cuando necesitemos.
  
 
===Instalando Mysql===
 
===Instalando Mysql===

Revisión de 16:50 29 sep 2015

DWES TituloTema2.gif



Aplicaciones Web
  • El hecho de que la página sea dinámica, hace referencia a que la página se crea una vez que se solicita, no se entrega una página previamente hecha.
ComparativaEstaticaDinamica.png


Icon casestudy.gif

Ejemplo

Vamos a comer: un menú fijo (página estática), o comemos a la carta (página dinámica).



  • Una Aplicación Web, funcionalmente puede hacer lo mismo que una aplicación de escritorio
  • La Aplicación Web, la puedo ejecutar desde cualquier ubicación.
DistribucionAplicacionesWeb.png

Aplicaciones Web Vs Escritorio

  • Las diferencias entre una aplicación web y una de escritorio tiene ventajas e inconvenientes.
Ventajas de las aplicaciones web
No es necesario instalarlas en aquellos equipos en que se vayan a utilizar.
Se instalan y se ejecutan solamente en un equipo, en el servidor.
Esto permite uso simultáneo en diferentes equipos.
Centralización de la gestión: hacer copias de seguridad de los datos, corrección de errores, actualización.
Ventajas de las aplicaciones Web
Independiencia del sistema operativo y de la arquitectura de la máquina (procesador, potencia, ...)
Generalmente el cuello de botella lo presenta el equipo, no la máquina.
Se pueden utilizar desde cualquier lugar en el que dispongamos de conexión con el servidor.
Ventajas.png
Inconvenientes
El interface de usuario de las aplicaciones web es la página que se muestra en el navegador.
Esto restringe las características del interface a aquellas de una página web.
Dependemos de una conexión con el servidor para poder utilizarlas.
Si nos falla la conexión, no podremos acceder a la aplicación web.
Inconvenientes.png
Inconvenientes
La información que se muestra en el navegador debe transmitirse desde el servidor.
Esto hace que cierto tipo de aplicaciones no sean adecuadas para su implementación.
Por ejemplo, las aplicaciones que manejan contenido multimedia, como las de edición de vídeo.
Al viajar la información por la red, existe un problema extra de seguridad.

Conceptos a tener claros para desarrollo web

  1. Framework
  2. Gestores de contenidos
  3. Plataforma de desarrollo
  4. Tecnología
  5. Arquitectura Web
  • No todos los conceptos hacen referenica al lenguaje de programación a utilizar
  • Son terminologías relacionadas con el desarrollo web

Organizando conceptos

  • A la hora de empezar a desarrollar, hay que tomar unas decisiones previas



Icon qmark.gif

Pregunta

Qué programación, Servidor Web, Gestor de Bases de datos voy a usar?


Organizando conceptos
  • Esto tiene que ver con
  1. Arquitectura
  2. Plataforma de desarrollo
  3. Tecnología
Arquitectura Web

Center

Herramientas para desarrollar

  1. Framework
  2. Gestor de contenidos CSM



Icon qmark.gif

Pregunta

¿Framework o _Gestores de contenidos?


Herramientas para desarrollar
FrameworkVsCSM.png


Framework
  • Filosofía de programa tus programas, no tus aplicaciones
  • Habla de dónde hay que dedicar esfuerzos
  • Una herramienta compuesta por una serie de librerías que nos da un enfoque y una forma de cómo solucionar un problema
  • Organiza la forma de desarrollo


Framework
  • Establece unos criterios que unifica la manera de desarrollar
    • Estructura de carpetas
    • Gestion de la base de datos
    • Automatización de muchas tareas (Autentificación, Cookies, Gestion de la base de datos, Seguridad
    • Permiten un mantenimiento
Gestores de contenidos
  • Son herramientas que permiten desarrollar contenidos
  • Por ejemplo Drupal, Joomla, Wrodpress y otras muchas.
  • En ellas siempre vemos dos partes bien diferenciadas:
  1. Una parte externa o front-end, que es el conjunto de páginas que ven los usuarios.
  2. Una parte interna o back-end, que es otro conjunto de páginas dinámicas
    1. Normalmente son las que usan las personas que producen el contenido
    2. Administrar la aplicación web permitiendo a usuarios con permisos acceder a contenidos.

Back-end y front-end de una aplicación web

  • Una aplicación web normalmente se divide en dos partes
  1. un front-end, que es la parte pública que ven los usuarios externos; (La página html)
  2. un back-end, que es la parte privada que usan los administradores de la aplicación. (Los programa en servidor, bd,...)

Programación en el servidor y en cliente

  • Ya hemos dejado hablado un poco de estas dos tecnologías


Icon key points.gif

Puntos clave

El cliente se ejecuta en el navegador


  • El código a ejecutar viene embebido en forma de script en la página que el servidor nos entrega.
  • Este script en principio no puede directamente acceder a los datos que tengamos en el servidor
Programación en el servidor y en cliente



Icon qmark.gif

Pregunta

Si quiero verificar que la contraseña introducida en una página web tenga una longitud mínima, ¿dónde sería preferible que se ejecutara el código de comprobación?


El servidor ejecuta código y genera páginas html que entrega al cliente
  • El cliente nunca ve este código
  • El servidor accede (si es necesario) a la información que tenemos en la base de datos
  • El servidor responde a una solicitud del cliente y le entrega una página html
  • No se puede pensar que el cliente necesita un dato y se lo pide al servidor y este se lo entrega.
  • Lo que entrega es una págian html. Esto debe quedar muy claro


Icon key points.gif

Puntos clave

El servidor ante una solicitud del cliente entrega una página html


AJAX Al rescate



Icon qmark.gif

Pregunta

  1. ¿Qué pasa cuando el cliente solo quiere un dato del servidor para actualziar la página que actual?
  2. ¿y si en un momento dado, sólo pretendemos almacenar algo y qudarnos como estamos?



  • Desde hace unos años existe una técnica de desarrollo web conocida como AJAX.
  • Esta tecnología nos posibilita realizar programas en los que el código JavaScript accede al servidor
  • se puede comunicar y obtener información con la que, por ejemplo, modificar la página web actual.
AJAX al rescate
  • Es importante tener en cuenta que esta comunicación es asíncrona (no sabemos exactamente cuando se va a producir la comunicación)


Icon key points.gif

Puntos clave

Ajax permite sin salir de una página modificar su contenido en base a la información que se almacena en un servidor de Internet



Tecnologías y Arquitectura web

  • Tiene que ver con las herramientas o programas a utilizar tanto para desarrollar y como para dar servicios



Tecnología y Arquitectura web
  • Nosotros de momento usaremos la arquitectura de tipo LAMP (Linux Apache Mysql Php)
  • Existen otras arquitecturas para desarrollar. Consiste en hacer convinacinoes de SO. Serivdor Web, Gestor de Bases de Datos, Lenguaje de programacion para el desarrollo).


Icon activity.jpg

Actividad

Localiza al menos 2 Arquitecturas diferentes



Tecnologías para programación web del lado del servidor

  • Cuando programas una aplicación, utilizas un lenguaje de programación.
  • Por ejemplo, utilizas el lenguaje Java para crear aplicaciones que se ejecuten en distintos sistemas operativos.
  • Al programar cada aplicación utilizas ciertas herramientas como un entorno de desarrollo o librerías de código. *Además, una vez acabado su desarrollo, esa aplicación necesitará ciertos componentes para su ejecución.
  • Por ejemplo en el caso de javauna máquina virtual de Java.
  • Son consideraciones a tener en cuenta antes de empezar a desarrollar.


Componentes de una aplicación web en el servidor

  • 1.-Un servidor web para recibir las peticiones de los clientes web
    • Suelen ser los navegadores. Reciben la página que solicitan
    • El servidor web debe conocer el procedimiento a seguir para generar la página web:

Para ello tendrá módulos encargados de la ejecución del código y cómo se debe comunicar con él.

Componentes de una aplicación web en el servidor
  • 2.-El módulo encargado de ejecutar el código o programa.
    • genera la página web resultante.
    • Este módulo debe integrarse de alguna forma con el servidor web
    • Dependerá del lenguaje y tecnología que utilicemos para programar la aplicación web.
  • 3.- Un gestor de base de datos, será un servidor.
    • Este módulo no es estrictamente necesario pero se usa casi siempre.
  • 4.-El lenguaje de programación que utilizarás para desarrollar las aplicaciones.

La arquitectura de la aplicación

  • Además de los componentes a utilizar, también es importante decidir cómo vas a organizar el código de la aplicación.
  • Esto se conoce como la arquitectura de la aplicación web.
  • Muchas de las arquitecturas que se usan en la programación de aplicaciones web te ayudan a estructurar el código de las aplicaciones en capas o niveles.
  • El motivo de dividir en capas el diseño de una aplicación es que se puedan separar las funciones lógicas de la misma, de tal forma que sea posible ejecutar cada una en un servidor distinto (en caso de que sea necesario).
Arquitectura de la aplicacion
  • Un servidor de aplicaciones web en realidad puede estar formado por varios servidores físicos;
cada servidor se puede encargar de ejecutar una parte de la aplicación. 
  • Internamente se puede dividir la funcionalidad de una aplicación web en3 capas (Cliente, Sevidor, BD).
Arquitectura de tres capas
  1. capa de acceso a datos: que se tendrá que encargar de almacenar la información de la aplicación en una base de datos y recuperarla cuando sea necesario.
  2. capa intermedia : donde deberás programar la funcionalidad de tu aplicación.
  3. capa cliente: que es donde programarás todo lo relacionado con el interface de usuario, esto es, la parte visible de la aplicación con la que interactuará el usuario.
  • Dentro de la arquitectura de la aplicacion podemos ver tambíen arquitectura MVC (nivel de tres capas), o arquitectura de modelo Vista - Aplicacion o modelo de dos capas.
  • Este tema lo estudiaremos posteriormente.


Icon inter.gif

Recursos de la Web


Instalación de herramientas

  • Las herramientas que vamos a necesitar para desarrollar son las siguietnes
  1. Netbeans como EDI de desarrollo. Alternativamente se puede usar Sublime u otros (Mejor usar todos el mismo
  2. Apache como servidor Web
  3. PHP como lenguaje de programación en el servidor
  4. HTML como páginas
  5. http como protocolo de comunicaciones

Instalando Apache

Apache.png
 apt-get install apache2
Directorio dónde se ubica todo
/etc/apache2
Modificando directivas de configuración
  • Localizamos el fichero de configuración del sitio web por defecto
/etc/apache2/sites_avaible/000-default.conf
  • Modificamos el DocumentRoot al directorio /var/www


Icon key points.gif

Puntos clave

  1. Fichero de configuracion
  2. Sitio web por defecto
  3. Directiva DocumentRoot
  4. Directiva ServerName
  5. Directiva <Directory> ... </Directory>



Icon activity.jpg

Actividad

  1. Probamos a ver si responde nuestro servidor web
  2. Vemos el fichero de configuración




  • Para parar y arrancar un servicio en linux se puede hacer
sudo service nombre_del_servicio start|stop|restart|status
 sudo service apache2 restart


Icon activity.jpg

Actividad

  • Intenta tener en local un sitio web llamado www.tuNombre.daw.com
  • Que se cargue una página web llamada 1.html ubicada por defecto en tu home/web (crea previamente el directorio
  • Explica en todos los pasos realizados




  • Apache es un proceso propiedad del usuario www-data que está en el grupo www-data
  • Para cambiar el propietario de un fichero se usa el comando
 sudo chown usuario:grupo fichero
  • Es muy importante conocer la ubicación del fichero donde se identifican los errores según se producen por parte del servidor
  • Muchas veces va a ser nuestro única forma de saber por qué algo está fallando


Icon key points.gif

Puntos clave

  • Fichero de errores /var/log/apache/error.log
  • Recuerda el comando sudo tail -f error.log(mantiene el fichero abierto y actualizado)


  • Existen otros modulos y extensiones de apache que ya instalaremos cuando necesitemos.

Instalando Mysql

Instalando php

Instalando Netbeans=

Instalando Netbeans
  • Primero debemos ver si tenemos instalado java
 java -version
  • Nos dirá la versión que actualmente tenemos instalada o que no lo tenemos.
  • En caso de no tenerla lo instalamos, podemos seguir esta guia
  • jdk, jre, jvm
  • Primero instamalos el jre
sudo apt-get install icedtea-7-plugin openjdk-7-jre
  • Luego el jdk
sudo apt-get install openjdk-7-jdk
  • Ahora verificamos la instalación
# java -version
java version "1.7.0_65"
OpenJDK Runtime Environment (IcedTea 2.5.2) (7u65-2.5.2-3~14.04)
OpenJDK 64-Bit Server VM (build 24.65-b04, mixed mode)

Instalar netbeans

  • Descargamos la última versión
https://netbeans.org/downloads/
  • No tiene ningún misterio la instalación
  • Debemos comprobar nuestro equipo sea de 64 bits o de 32
# uname -a
  • Seleccionamos la descarga de php y la máquina virtual de java por si no la tuviéramos instalada
  1. http://niconsystem.wordpress.com/2014/04/17/instalar-netbeans-8-0-en-ubuntu-14-04/
  2. http://ubuntuhandbook.org/index.php/2014/03/install-netbeans-ide-8-0-in-ubuntu-14-0413-1012-04/
  • Accedemos al fichero descargado
  • Le damos permiso de ejecución y ejecutamos dicho fichero
chmod +x jdk-8u20-nb-8_0_1-linux-x64.sh 
./jdk-8u20-nb-8_0_1-linux-x64.sh
  • Una vez instalado se puede ejecutar y no hace falta modificar ningún parámetro

Montando nuestra arquitectura Instalar Apache php y MySql

  • Seguimos la instalación de lamp
  1. http://www.howtoforge.com/installing-apache2-with-php5-and-mysql-support-on-ubuntu-12.04-lts-lamp
  2. instalamos mysql
  • Durante la instalación nos pedirá la contraseña de root
  • Probamos a entrar y que funciona bien
 mysql -u root -p
 '''insertamos la password'''
 show databases:
 
 use my_baseDatos;  
 
 SELECT database();


Icon activity.jpg

Actividad

Creamos una tabla e insertamos filas. Luego verificamos todo



Ahora debemos instalar php5 y el módulo correspondiente para apahce

Idioma no válido.

Necesita especificar un idioma como esto: <source lang="html4strict">...</source>

lenguajes soportados para sintaxis remarcada:

4cs, 6502acme, 6502kickass, 6502tasm, 68000devpac, abap, actionscript, actionscript3, ada, algol68, apache, applescript, apt_sources, arm, asm, asp, asymptote, autoconf, autohotkey, autoit, avisynth, awk, bascomavr, bash, basic4gl, bf, bibtex, blitzbasic, bnf, boo, c, c_loadrunner, c_mac, caddcl, cadlisp, cfdg, cfm, chaiscript, cil, clojure, cmake, cobol, coffeescript, cpp, cpp-qt, csharp, css, cuesheet, d, dcl, dcpu16, dcs, delphi, diff, div, dos, dot, e, ecmascript, eiffel, email, epc, erlang, euphoria, f1, falcon, fo, fortran, freebasic, freeswitch, fsharp, gambas, gdb, genero, genie, gettext, glsl, gml, gnuplot, go, groovy, gwbasic, haskell, haxe, hicest, hq9plus, html4strict, html5, icon, idl, ini, inno, intercal, io, j, java, java5, javascript, jquery, kixtart, klonec, klonecpp, latex, lb, ldif, lisp, llvm, locobasic, logtalk, lolcode, lotusformulas, lotusscript, lscript, lsl2, lua, m68k, magiksf, make, mapbasic, matlab, mirc, mmix, modula2, modula3, mpasm, mxml, mysql, nagios, netrexx, newlisp, nsis, oberon2, objc, objeck, ocaml, ocaml-brief, octave, oobas, oorexx, oracle11, oracle8, oxygene, oz, parasail, parigp, pascal, pcre, per, perl, perl6, pf, php, php-brief, pic16, pike, pixelbender, pli, plsql, postgresql, povray, powerbuilder, powershell, proftpd, progress, prolog, properties, providex, purebasic, pycon, pys60, python, q, qbasic, rails, rebol, reg, rexx, robots, rpmspec, rsplus, ruby, sas, scala, scheme, scilab, sdlbasic, smalltalk, smarty, spark, sparql, sql, stonescript, systemverilog, tcl, teraterm, text, thinbasic, tsql, typoscript, unicon, upc, urbi, uscript, vala, vb, vbnet, vedit, verilog, vhdl, vim, visualfoxpro, visualprolog, whitespace, whois, winbatch, xbasic, xml, xorg_conf, xpp, yaml, z80, zxbasic


apt-get install php5 libapache2-mod-php5
</sh>
*Debemos restaurar el servicio para que los cambios tengan efecto en el servidor web
<source lang=bash>
/etc/init.d/apache2 restart


Icon activity.jpg

Actividad

  • Localiza el fichero de configuracion de php: php.ini
  • Analiza el valor y significado de las siguientes directivas
  1. short_open_tags
  2. max_execution_time
  3. error_reporting
  4. file_upload
  5. upload_max_filesize




Instalar xdebug

  • Podemos consultar la pagina de netbeans para la informacion
https://netbeans.org/kb/docs/php/configure-php-environment-ubuntu.html#xdebug-package
sudo apt-get install php5-dev php-pear
 sudo pecl install xdebug
  • A continuacion debemos modificar el fichero ini de php
  • Abrimos con nuestro editor el fichero
 sudo vim /etc/php5/apache2/php.ini .
  • Añadimos el módulo de xdebug a la variable zend_extenxion de php
zend_extension=/usr/lib/php5/<DATE+lfs>/xdebug.so
xdebug.remote_enable=on
<source>
|}
</div>