Capítulo 4. Herramientas para el desarrollo del sistema



Documentos relacionados
Capítulo VI. Conclusiones. En este capítulo abordaremos la comparación de las características principales y

JAVA EE 5. Arquitectura, conceptos y ejemplos.

Modulo I. Introducción a la Programación Web. 1.1 Servidor Web.

La utilización de las diferentes aplicaciones o servicios de Internet se lleva a cabo respondiendo al llamado modelo cliente-servidor.

Capítulo 7. Implementación del Sistema

Capítulo I. Definición del problema y objetivos de la tesis. En la actualidad Internet se ha convertido en una herramienta necesaria para todas

CORPORACIÓN MEXICANA DE INVESTIGACIÓN EN MATERIALES, S.A. DE CV

CAPÍTULO 5 IMPLEMENTACIÓN DEL SISTEMA

Propuesta de Portal de la Red de Laboratorios Virtuales y Remotos de CEA

Capitulo 5. Implementación del sistema MDM

Proyecto ELO-330 Administración Salas del Departamento de Electrónica RC1. Gerardo Lecaros Felipe Díaz

desarrollo. Dentro del desarrollo de la tesis el proceso de modelado del sistema fue hecho con el

Capitulo III. Diseño del Sistema.

Notas técnicas de JAVA Nro. 7 Tip Breve

Capítulo 3 Diseño del Sistema de Administración de Información de Bajo Costo para un Negocio Franquiciable

Windows Server Windows Server 2003

CAPÍTULO 3 VISUAL BASIC

Capítulo II. Arquitectura del Software

Unidad V: Programación del lado del servidor

A continuación resolveremos parte de estas dudas, las no resueltas las trataremos adelante

JSP(JAVA SERVER PAGES)

GLOSARIO. Arquitectura: Funcionamiento, estructura y diseño de una plataforma de desarrollo.

Introducción al Desarrollo de Aplicaciones Web D R A. M A R I C E L A B R A V O

Intervención General de la Administración del Estado

Introducción a la extensión de scripting en gvsig 2.0

Capítulo I. Marco Teórico

GUÍA TÉCNICA. Desarrollo de Sistemas de Información la plataforma Business Intellingence Pentaho

Visión General de GXportal. Última actualización: 2009

Workflows? Sí, cuántos quiere?

computadoras que tienen este servicio instalado se pueden publicar páginas web tanto local como remotamente.

Windows Server 2012: Infraestructura de Escritorio Virtual

Qué es una aplicación web

Formatos para prácticas de laboratorio

Capítulo 5. Cliente-Servidor.

2.3. Lenguajes de programación del lado Servidor. ASP.NET (Active Server Pages).

Apéndice 5 Manual de usuario de ColeXión. ColeXión 1.0. Manual de usuario

Capítulo 2. Planteamiento del problema. Capítulo 2 Planteamiento del problema

Panorámica de la asignatura

Web. Web Diapositiva 1

Objetivo: Introducción conceptual y aplicación básica de los lenguajes del lado del servidor.

XPERTO EN DISEÑO DE PÁGINAS WEB

PORTAL DE INTEGRACIÓN DE BANCOS DE INFORMACIÓN DISPERSOS A TRAVÉS DE WEB SERVICES Autor: Ing. Walther Antonioli Ravetto

CAPÍTULO 1 INTRODUCCIÓN

CMS JOOMLA. Características

Arquitectura. 1.- Aplicaciones Web. Definición. Arquitectura clásica. Contenidos. 1.- Aplicaciones Web

Curso de HTML5 y CSS3

Productos para desarrollar aplicaciones web: ASP, CFM, JSP y PHP

Programación páginas web con ASP.NET 3.5 (C#)

Estándares para el Uso de Herramientas de Desarrollo y Plataformas de Aplicaciones Web

Capítulo III. Análisis y diseño.

Curso de JavaServer Faces

VISIÓN GENERAL HERRAMIENTAS COMERCIALES

Capitulo VI. Conclusiones.

<HTML> <IMG src= logo.gif > </HTML> Lógica de negocio. Dsfg dsfg sdfg. Sdfgdfg dfg Dsf gsdfg sdfg. Dfg. Sdfgdfg dfg. Dfg. Dsf gsdfg sdfg.

CAPÍTULO 4 ANÁLISIS Y DISEÑO: e-commerce CONSTRUCTOR

Creación y administración de grupos de dominio

Introducción a WebMathematica

Capítulo 1 Documentos HTML5

Apéndice A Herramientas utilizadas

Creación y administración de grupos locales

Modelo de Objetos Distribuidos

Maxpho Commerce 11. Gestión CSV. Fecha: 20 Septiembre 2011 Versión : 1.1 Autor: Maxpho Ltd

19. Packages o paquetes

Microsoft SQL Server Conceptos.

Internet Servicios WEB (WWW)

Acronis License Server. Guía del usuario

Internet, conceptos básicos

1 El trabajo expuesto está subvencionado por el proyecto de la URJC PGRAL-2001/14

Tema 1. Introducción a JAVA

aplicaciones web: ASP, CFM, JSP y PHP

Transacciones: 2PC y 3PC. Aplicaciones de Internet: HTTP/Applets, HTTP/GCI y Java Servlets

Unidad II. - Las técnicas en las que se basó, las categorías de análisis o ejes centrales que permiten guiar el proceso de investigación.

GUÍA Nro. 1 TECNOLOGÍA DE INTERNET. TIII PIII

Configuracion Escritorio Remoto Windows 2003

Módulo 2. Inicio con Java

Comparación entre Active Reports, Crystal Reports, y MS Reporting Services

Oracle vs Oracle por Rodolfo Yglesias Setiembre 2008

Elementos requeridos para crearlos (ejemplo: el compilador)

Introducción a los sitios de SharePoint en Office 365

MANUAL DE USUARIO CMS- PLONE

Facultad de Ingeniería Escuela de Ciencias y Sistemas Estructura de Datos Guatemala 2013 JSF + JSP + RichFaces

CAPITULO 3 MOVILIDAD EN LA NAVEGACIÓN Y ALMACENAMIENTO EN BASES DE DATOS

WINDOWS : TERMINAL SERVER

Mi propuesta consiste en crear un portal Web que contemple las siguientes funcionalidades:

Fundamentos de programación Estudia las estructuras de control y cómo definir funciones en JavaScript.

Tecnologías Web. Clientes. Servidores. Opciones en cliente: Opciones en servidor. Netscape, Explorer, Opera. Apache, IBMHTTPServer, IIS

Programador en Plataforma Java y XML

Guía de uso del Cloud Datacenter de acens

App para realizar consultas al Sistema de Información Estadística de Castilla y León

Desarrollo de Software con

Visualización y modelado de elementos geográficos en dispositivos móviles. Capítulo 5: Aplicaciones cliente

Capítulo 6 Introducción a los Sistemas Operativos de Redes (NOS)

GeneXus BPM Suite X. Última actualización: 01 de Setiembre de 2008

INSTITUTO TECNOLÓGICO DE COLIMA LIC. EN INFORMÁTICA

Generador GeneXus JAVA

arquitectura que maneja. Encontraremos también los diferentes servidores que

Técnicas de Programación

Los mayores cambios se dieron en las décadas de los setenta, atribuidos principalmente a dos causas:

Toda base de datos relacional se basa en dos objetos

Descripción. Este Software cumple los siguientes hitos:

Transcripción:

Capítulo 4. Herramientas para el desarrollo del sistema 4.1 Java Serve Pages (JSP) La tecnología de JavaServer PagesTM (JSP TM) permite a los desarrolladores y a los diseñadores de Web desarrollar rápidamente y mantener fácilmente páginas dinámicas, ricas en información como son las que soportan a sistemas de negociación. La tecnología de los JSP separa la interfaz del usuario de la parte lógica del contenido permitiendo a los diseñadores cambiar a su disposición las plantillas de la interfaz sin alterar el contenido dinámico subyacente [Big-boys, 2001]. Otra definición es que es una tecnología de Java que permite introducir código para la generación dinámica de HTML dentro de una página web. Esta surge por la necesidad de crear aplicaciones dinámicas para Web de forma fácil, ya que la mayor parte del resultado de un programa CGI es estático. Se podría pensar entonces en JavaScript, pero este genera HTML dinámicamente en el cliente y no puede acceder a los recursos del servidor. La ventaja como ya se dijo es que permite diseñar la página web y el código de forma independiente. Las páginas JSP pueden residir en cualquier parte del servidor (no están restringidas a un directorio servlets). En otras palabras, un JSP es simplemente una página de Web en HTML que contiene dígitos binarios adicionales de código que ejecuta la lógica de la aplicación para generar contenido dinámico. Esta lógica de la aplicación puede implicar el uso de JavaBeans, objetos de JDBC, Enterprise Java Beans (EJB), u objetos de RMI, los cuales pueden ser fácilmente accesados desde un JSP. Por ejemplo, un JSP puede contener código HTML que despliega texto y gráficos estáticos, y además puede invocar a métodos de un objeto de JDBC (Bean) que tenga acceso a una base de datos; cuando se despliegue la página en el browser de un usuario, ésta contendrá el contenido estático HTML y la información dinámica extraídos de la DB. Es de esta forma en la que la mayor parte del CILE está modelada y desarrollada y es gracias al uso de Beans que fue posible por lo que a continuación haré una breve descripción de ellos. En la 33

figura 4.1 se muestra un diagrama de su funcionamiento en conjunto con los demás componentes que hicieron posible el desarrollo del CILE. Figura 4.1 Modelado del funcionamiento de un JSP con Beans y una DB. Dentro de JSP existen diferentes acciones una de ellas es la que hace uso de los Beans y se identifica con el nombre jsp:usebean y se describe como a continuación se hace: <jsp:usebean id=?nombre? class=?paquete.clase? /> Esto permite obtener una referencia a un Bean (componente Java), as instancias de los componentes pueden ser compartidas. Las clases de los Beans deben estar en el CLASSPATH del servidor. Inicialización del bean: <jsp:usebean... > Cuerpo </jsp:usebean> Cuerpo: código JSP ejecutable la primera vez que se instancia el Bean. id: nombre de la variable que contendrá la referencia al Bean. class: indica la clase del Bean scope (opcional): indica el contexto en el que el bean estará disponible: page (por default): disponible sólo para la página. request: disponible sólo para la petición. session: disponible durante la sesión. application: para las páginas que compartan ServletContext. 34

Otra ventaja de los JSP es que se compilan automáticamente según se vaya necesitando, es así que se pueden realizar cambios sin recompilar la lógica de la aplicación, simplemente se le hace un reload o un refresh al navegador para visualizar los cambios. Esto hace a JSP un método más flexible para generar contenido dinámico para el Web que los servlets de Java, ya que en éstos los cambios al código de la presentación requieren la modificación y la recompilación del archivo fuente del servlet. Los JSP solo heredan la funcionalidad de los servlets como después se especificará. Una página JSP se convierte en un servlet para su ejecución, ya que es compilada a un servlet la primera vez que se solicita. El último paso del desarrollo de una JSP es realizar una petición. 4.1.1 Cómo se accesa a JavaServer Pages? Para realizar una petición de una página JSP se sigue una forma similar al de una página HTML estática, aunque el demás proceso, el cual es transparente para el usuario es diferente. Para una página no dinámica se teclea un URL en el browser y éste usando un protocolo HTTP mandará una petición del archivo con extensión html (ej. archivo.html) a un servidor Web (ej. translator) y dominio determinado (go.com). Posteriormente el servidor extraerá el archivo y lo mandará a el browser, el cual hace uso de las etiquetas de HTML del archivo para ser presentarlo a l usuario final. En el otro caso para una página dinámica se hace la petición de un archivo con extensión jsp (ej. article.jsp) y de este punto en adelante las cosas cambian empezando con que no solo se puede hacer la petición desde un browser sino también desde un servlet o de otra página JSP. La petición llegará también a un servidor Web pero que será capaz de reconocer la extensión jsp y que mandé la petición a un contenedor JSP, el cual invoque el método _jspservice() de la página JSP compilada. La respuesta dada por este método será enviada al contenedor y de éste al usuario. 4.2 Características de JSP A continuación se dará en resumen las características de esta tecnología: 35

Conjunta el poder de Java en el servidor y la flexibilidad de HTML (HyperText Markup Language) en el browser. No sólo se puede utilizar HTML, sino también XML ( extensible Markup Language) o WML (Wireless Markup Language). Hace más fácil reusar componentes como JavaBeans y Enterprise JavaBeans los cuales realizan tareas más específicas. Forma parte integral de Java 2 Enterprise Edition (J2EE). Su función es saber como procesar una solicitud para crear una respuesta. Soporta contenido dinámico que refleja las condiciones del mundo real. Existe independencia entre la parte del diseño (interfaz) y la lógica (programa). 1. Write Once, Run Anywhere TM, independencia de plataforma.?mejora del performance. No se tiene que ir al servidor cada vez que se haga una solicitud, por lo tanto soluciona el problema del cuello de botella.?ante un cambio se compila automáticamente. Ya que se realizó un precompilado en el servlet antes de ser usado.?es más rápido y fácil crear aplicaciones de Web.?Capaz de instanciar cualquier clase de Java.?Corre en todos los servidores de Web principales. 4.3 JSP y otras tecnologías 4.3.1 JSP vs CGI Los CGI s (Common Gateway Interface) es la tecnología vieja para realizar peticiones de tipo HTTP en una aplicación de servidor y se hacía uso de PERL, C++ o Python para su desarrollo. Cuando una petición se mandaba del browser a un sitio Web, el CGI solo requería al servidor para ser un puente entre la petición del cliente y el script, y se preparaba para recibir la respuesta y regresarla al cliente o usuario. Algo nada eficaz es que cada petición genera un nuevo proceso cada vez que la respuesta ha sido enviada por lo que se crean los fastidiosos cuellos de botella y la aplicación se vuelve lenta. Su implementación no hace uso 36

de threads para cada petición, ni mantiene código en la memoria para mantener el performance y escalabilidad. Realmente no tiene mucho soporte para construcción de aplicaciones web. En comparación los JSP mantienen el estado en el servidor entre las peticiones, ya que se usan las sesiones de Servlets. Crea un nuevo thread para cada peticion. No tiene que ser reiniciado cada vez que se requiera, una vez que ha sido iniciado. Corre en ready loaded JVM (Java Virtual Machine) como una extensión del servidor de Web [Avedal, 2000]. Tecnología JSP ASP Plataformas Cualquier plataforma que sea Microsoft Windows soportada por Java (Solaris, Linux, Windows NT, Mac OS, AIX, HP-UX y una variedad de variantes de UNIX) Servidor Web Cualquiera. Los más populares Microsoft IIS o Personal Web como Apache, Netscape, IIS. Server Lenguaje Scripting Java VBScript, JavaScript Componentes reusables y de JavaBeans, No cross plataforma Enterprise JavaBeans Protección de memoria de Si No escape Etiquetas especiales Si No Integración de bases de datos Cualquier Base de Datos que Cualquier Base de Datos que soporte tecnología JDBC u soporte tecnología ODBC ODBC Interpretación de código Una sola vez En cada caso Componentes JavaBeans, Enterprise JavaBeans Extensiones JSP COM / DCOM Tabla 4.1 Comparación entre JSP y ASP 37

4.3.2 JSP vs ASP ASP (Active Server Pages) es otra tecnología similar a JSP por lo tanto ésta no es la única ni la más conocida ya que ASP fue desarrollada por Microsoft y como todos sabemos es la plataforma con más usuarios en el mundo. Puede combinar HTML, las escrituras y los componentes reutilizables del servidor de ActiveX para crear también páginas dinámicas de Web [Big-boys, 2001]. Ambas tecnologías son alternativas viables para los CGI s, sin embargo hay diferencias significativas entre las dos [Tremblett, 2000]. En JSP el código está escrito en Java y es portable entre sistemas operativos. En la tabla 4.1 se muestra una tabla con una comparación entre JSP y ASP. 4.3.3 JSP vs Servlets La especificación de JSP está construida bajo el API de Java Servlet ya que los Servlets proveen la habilidad de construir contenido dinámico para sitios Web usando a Java como lenguaje. Sin embargo JSP trabaja de una manera más limpia o clara la separación de la presentación de la parte lógica y además es simple de escribir. Ambas tecnologías trabajan mejor en conjunto [Avedal, 2000]. Como ya se comentó los JSP son una extensión del API de Servlets. De hecho, las páginas de JSP se compilan en servlets antes de que se utilicen, así que tienen todos las beneficios de los servlets, incluyendo el acceso al API de Java. Debido a que los JSP son generalmente código de presentación (por ej. HTML) con la lógica de la aplicación incrustada (por ej. Java), se puede pensar en ellos como en servlets "inside-out". Además facilita el mantenimiento de la aplicación. 4.4 Aplicaciones de JSP Para una mayor visualización de las áreas de cómputo donde se puede desarrollar la tecnología JSP se muestran la siguiente tabla (ver tabla 4.2), cabe destacar que dicha tecnología se puede aplicar en muchas más aplicaciones a las aquí mencionadas, como es el 38

caso del CILE a desarrollar o de un desarrollo de aplicaciones para la construcción de sitios interactivos en Internet para el comercio electrónico. Se describirán a continuación unos ejemplos de aplicaciones existentes. Ad Management Bulletin Board Systems Calendar & Time Chat Content Management Document Management Email File Management Graphics & Charts Guest Book Search & Directory Shopping & Commerce Site Statistics Vote & Questionnaire Tabla 4.2 Algunas áreas donde desarrollar aplicaciones en JSP. esearch Para los negocios y las organizaciones que dependen del acceso rápido y confiable a la información, hay una mejor opción - recuperación de datos con una máquina de búsqueda para el uso en una intranet o en el Internet. De la retroalimentación de la comunidad de desarrolladores se creó una lista de características y de funciones deseadas. Desarrollo bajo JSP 1.2 [Jcorporate, 2001]. La lista es la siguiente: 1. Desarrollado en Java, y por lo tanto con plataforma - independiente. 2. Que provea las capacidades básicas de la búsqueda comparables a otros buscadores existentes para intranet e Internet. 3. Que permita capacidades básicas para incluir agentes inteligentes y otros comportamientos de sistemas expertos. 4. Escalable a las dimensiones verdaderamente de colecciones y de usuarios. 5. Que pueda indexar dinámicamente múltiples servidores y fuentes simultáneamente. e-commerce Constructor Está aplicación realiza la creación, administración y presentación de información de una Tienda Virtual que posteriormente se genera dinámicamente y es utilizada para el proceso de 39

eventos y acciones así como la producción de servicios. Trabaja en una arquitectura Cliente/Servidor llamada Web Sales Server que provee la manipulación de datos, así como su presentación y almacenamiento. Éste sistema se presenta como una herramienta para su aplicación en la Comercio Electrónico (e-commerce en inglés) en específico en su modelo de negocio denominado: Tienda Virtual (e-shop en inglés). Y como un esfuerzo de crear una base de conocimientos para el desarrollo de aplicaciones para la construcción de sitios dinámicos e interactivos en el Web. La decisión de diseñar una aplicación para el Comercio Electrónico se toma del gran auge de esta actividad electrónica, y en una respuesta al desarrollo de aplicaciones que faciliten procesos, disminuya costos y permita aplicar soluciones a situaciones reales así como tener la oportunidad de expansión [Fuentes, 2001]. 4.5 Java Media Framework (JMF) Dentro del área del desarrollo de tecnologías de la información se han creado herramientas capaces de implementar multimedios no solo como aplicaciones de diseño como son Flash, Director entre otros, sino que también dentro de los lenguajes de programación tan poderosos como es el de Java. Pues bien empezaré dando una breve descripción la cual especifica a grandes rasgos lo que es JMF. Java Media Framework es una aplicación de interface (API) la cual incorpora audio, video y otras medias basadas en tiempo dentro de las aplicaciones y los applets de Java. Es un paquete opcional para extender las capacidades de multimedia de la plataforma J2SE (Java 2 Standard Edition). (describir que quieren decir estas siglas) [JMF, 2001]. En otras palabras podemos decir que JMF es un paquete extra que posee la plataforma J2SE, la cual proporciona clases para agregar tecnologías de información a la programación en Java. Esta herramienta es de lo más reciente que se ha desarrollado para la plataforma UNIX y se cree que tiene un gran futuro dentro de los desarrollos de tecnología que proveen multimedia, ya que detrás de ella existe el respaldo del poderoso lenguaje de Java. 4.5.1 Características de JMF 40

Dentro de las características de Java Media Framework se encuentran las siguientes: Los diferentes estándares para el desarrollo de la transmisión de video en tiempo real. Mediante su tecnología permite poner en ejecución soluciones basadas en el API existente. Fácilmente integra nuevas características con el marco existente. Proveé el acceso a los datos de media sin procesarlos. Permite el desarrollo de customs, demultiplexores, multiplexores, procesadores de efectos y rendereadores mediante plug-ins especiales de JMF. Mantiene compatibilidad con versiones anteriores (JMF 1.0). Pero es recomendable tener presente que hay que verificar las versiones para saber que es lo que se va renovando o cambiando en cada una de ellas. 4.5.2 Ventajas y desventajas Como toda tecnología JMF cuenta con ciertas ventajas y desventajas, así que es conveniente mencionarlas y aclararlas de la mejor manera. Una de sus fuertes ventajas se ve ampliamente en la parte de transmisión de video en tiempo real, ya que ésta es totalmente gratuita, no es necesario contar con otra aplicación que involucre un gasto, como lo es la de Real Player de la plataforma Macintosh o la de Windows Media Player para la plataforma de Windows. Tal vez podría mencionar como desventaja en este punto que para que se realice tal tarea es necesario que la computadora del usuario cuente con alguna versión de JMF, es decir que se instale ésta en la máquina, siendo esto no del todo sencillo, no para cualquier tipo de usuario, sino que va tener que recurrir a un especialista en el área, siendo esto algo tedioso para la persona que requiera de este servicio. La virtud de JMF como ya se comentó es la de capturar, correr, transmitir y codificar audio, video y otras medias dadas por los desarrolladores de multimedia. Desarrollo que tiene en aplicaciones a través de diferentes plataformas y en applets. Otras ventajas que podríamos mencionar son las siguientes: 41

1.- Es fácil de programar. 2.- Soporta la captura de datos de media. 3.- Capaz de desarrollar media streaming y aplicaciones de conferencias bajo la tecnología de Java. 4.- Provee el acceso a los datos de media sin procesarlos. 5.- La nueva versión es compatible con la de JMF 1.0. 6.- La transmisión de video en tiempo real es gratis, siempre y cuando se cuente con una versión instalada en la máquina a usar. En el caso del desarrollo de este proyecto recurrimos a esta tecnología debido a que no existe el plug-in de QuickTime para Solaris para poder visualizar video. Cabe mencionar que no se pretende desarrollar aplicaciones de media streaming o transmitir estos videos en tiempo real, solamente se prentende visualizarlos mediante el uso de un applet. Cabe mencionar que no es necesario que el usuario de Solaris tenga que instalar alguna versión de JMF para hacer uso de ella. Al estar las librerías instaladas en el servidor de Web en donde también estará el.class de la clase es suficiente para que sean usadas por el usuario a través del servidor. Otro punto a tratar es el del desempeño / velocidad con el que cuentan los applets y más tratándose de un multimedio con es el de video. Es recomendable entonces que el usuario haga uso del plug-in de Java que viene incluido en el J2RE (Java 2 Runtime Environment) para tener un mejor desempeño de los applets. Aunque podemos regresar a la misma desventaja de JMF comentada anteriormente de que dicha instalación no del todo sencilla para cualquier tipo de usuario, sino que se va a tener que recurrir a un especialista en el área. Por otro lado puedo comentar que JMF ha hecho posible que los usuario de plataforma UNIX puedan contar con multimedios y a los desarrolladores poder desarrollarlos en sus aplicaciones. 42