Reutilización de software

Tamaño: px
Comenzar la demostración a partir de la página:

Download "Reutilización de software"

Transcripción

1 Reutilización de software A nivel de clase: Clases y algoritmos JGL A nivel de diseño Patrones de diseño A nivel de arquitectura Arquitectura J2EE 1

2 Aplicaciones Web Servidor Introducción a la arquitectura J2EE 2

3 Índice Introducción Servidor de aplicaciones Arquitectura de aplicación J2EE Desarrollo de EJB s (parte 2) 3

4 Introducción Objetivo Desarrollar, implantar y ejecutar componentes de lógica de negocio en la plataforma J2EE Java 2 Enterprise Edition 4

5 Introducción Dónde lo implementamos? Heterogeneidad: Plataforma: Unix/Linux, Windows, Mac/OS Lenguaje lógica: Java, C++, c#, Perl Fabricante: Oracle, IBM, HP, Microsoft Plataforma J2EE (Sun Microsystems): Define una arquitectura de desarrollo (n niveles) Define una serie de especificaciones para el desarrollo de aplicaciones en internet. No implementa ningún software Únicamente está especificaciones compuesto por un conjunto de Los fabricantes desarrollan servidores de aplicaciones que cumplen las especificaciones J2EE Permite la migración de un fabricante a otro fácilmente. 5

6 Introducción J2EE: Distribución básica multinivel Nivel Cliente Nivel (es) servidor de aplicación Nivel Datos Apps Presentación Lógica Servicios API Servicios API 6

7 Introducción El API de J2EE Java Servlets 2.3 Java Server Pages (JSP) 1.2 Enterprise Java Beans (EJB) 2.0 JDBC 2.0 Java Message Service (JMS) 1.0 Java Transaction API (JTA) 1.0 Java Mail 1.2 Java Beans Activation Framework (JAF) 1.0 Java API for XML Parsing (JAXP) 1.1 The Java Connector Architecture (JCA) 1.0 Java Authentication and Authorization Service (JASS) 1.0 7

8 Servidor de aplicaciones Es un software que da soporte a los componentes de servidor Proporciona un entorno de ejecución para los componentes Los componentes de servidor utilizan los servicios del servidor de aplicaciones Tareas de infraestructura: Instalación de componentes Comunicación Sincronización de acceso concurrente Preparación de un entorno seguro Seguridad en las transacciones 8

9 Servidor de aplicaciones Servicios ofrecidos Servicio de nombres: acceso a componentes y recursos a través de nombres lógicos Java Naming and Directory Inteface(JNDI) Servicio de transacciones: ejecución de una serie de pasos de forma atómica y aislada Java Transaction Service (JTS) Servicio de seguridad: directivas de seguridad para recursos protegidos Java Authentication and Authorization Service(JAAS) Persistencia: almacenamiento persistente de objetos y estados de objetos, normalmente en BD relacionales JDBC Comunicación: distintas técnicas de comunicación Comunicación Web: TCP/IP, UDP/IP,HTTP1.0 y HTTPS Procesador de objetos distribuidos: RMI-IIOP Servicios de configuración y administración: empaquetamiento, instalación y configuración flexible de componentes y la administración de aplicaciones Descripción mediantes esquemas XML de las características de servidores, containers y otro servicios. 9

10 Arquitectura de aplicación J2EE Nivel Cliente Nivel (es) servidor de aplicación Nivel Datos Cliente web Web container EJB container Bases de datos Aplicaciones legadas Cliente Java Servlets, JSP Enterprise JavaBeans Servicios y API s, JNDI, RMI-IIOP Servicios y API s, JNDI, RMI-IIOP Servicios y API s, JNDI, RMI-IIOP Sistemas ERP J2EE J2EE J2EE 10

11 Arquitectura J2EE 11

12 Aplicación J2EE desde cliente Java 12

13 Enterprise (Java)Beans (EJB) Es una especificación completa para el desarrollo de componentes de negocio Objetivos de la arquitectura de componentes EJB: Facilitar el desarrollo de aplicaciones, concentrándose en la lógica de negocio Independencia del proveedor de componentes mediante la utilización de interfaces Independencia de la plataforma, gracias a la utilización del lenguaje Java 13

14 Aplicaciones Web Servidor Desarrollo de EJB s

15 Índice Tecnología utilizada Arquitectura Desarrollo de un EJB Clasificación de EJB s Los Session Bean 15

16 Tecnología utilizada RMI-IIOP: Invocación de objetos remotos mensaje mensaje Cliente Internet EJB JNDI: Localización de los objetos remotos 16

17 Invocación remota de objetos: RMI-IIOP Queremos que los objetos del servidor se abstraigan de los aspectos relacionados con la comunicación remota Cliente Objeto remoto Interfaz remota Interfaz remota Stub Skeleton La tarea mas importante de los Stubs y Skeleton consiste en serializar los objetos que se envían como parámetro 17

18 Invocación remota de objetos: RMI-IIOP Separación interfaz y lógica Para construir y usar una clase Kaixo remota con el método iepa(string n) debemos: Definir una interfaz IKaixo con el método iepa(string n) que extienda la interfaz java.rmi.remote y hacer que este método declare la interfaz RemoteException Definir una clase KaixoImp que implemente la interfaz Kaixo Llamar al compilador RMI (rmic) para que cree las clases KaixoStub y KaixoSkeleton Crear al menos un objeto de la clase KaixoImpl y darle un nombre Un cliente debe localizar el objeto remoto, obtener el stub y realizar las llamadas al stub. El cliente debe tener en su máquina virtual la clase KaixoStub.class 18

19 Jerarquia de clases class java.rmi.server.unicastremoteobject interface java.rmi.remote -- CLASE REMOTA -- INTERFAZ REMOTA extiende class KaixoImp +iepa(n:string):void -- CLASE REMOTA implementa extiende interface IKaixo + iepa(n:string):void -- INTERFAZ REMOTA class Cliente kaixo: IKaixo usa -- CLASE CLIENTE 19

20 Invocación remota de objetos: RMI-IIOP Ejemplo: la interfaz IKaixo import java.rmi.remote; import java.rmi.remoteexception // La interfaz remota del objeto remoto. Los clientes // utilizarán esta interfaz para invocar el objeto remoto public interface IKaixo extend Remote { public String iepa(string n) throws RemoteException; } 20

21 Invocación remota de objetos: RMI-IIOP Ejemplo: la implementación Kaixo import java.rmi.remoteexception import java.rmi.portableremoteobject; public class KaixoImp extend PortableRemoteObject implements IKaixo{ public KaixoImp throws RemoteException { super(); } public String iepa(string n) throws RemoteException { return ( iepa +n); } } 21

22 Búsqueda remota de objetos: JNDI Servicios de naming y directory Mecanismo para la búsqueda de: Máquinas, Impresoras, drivers Consiste en asociar a un nombre lógico un elemento físico Código Cliente JNDI Client API Service Provider Interface LDAB Service Provider NIS Service Provider File System Service Provider 22

23 Búsqueda remota de objetos: JNDI Servicios de naming y directory Cliente Code 2: Buscar el objeto en un árbol JNDI conocido 3: return Stub Initial Context 4: Invocación método remoto RMI-IIOP Stub Máquina #1 5: Delegar RMI-IIOP Skeleton 1: Almacenar el objeto remoto en el árbol JNDI 6: Delegar RMI-IIOP Remote Object Máquina #2 Máquina #3 23

24 Búsqueda remota de objetos: JNDI Almacenar el objeto remoto en el árbol JNDI Crear una instancia del objeto remoto Localizar el contexto objeto del árbol y la máquina Ubicar el objeto en el contexto 24

25 Búsqueda remota de objetos: JNDI Servicios de naming y directory Import javax.naming.*; public class Startup { public static void main(string args[]) Throws Exception { // Crear una instancia del objeto IKaixo kaixoinstance= new Kaixo(); // Localizar el objeto en el árbol JNDI InitialContext ctx=new InitialContext(System.getProperties()); ctx.rebind( KaixoObj, kaixoinstance); synchonized(kaixoinstance) { kaixoinstance.wait(); } } } 25

26 Búsqueda remota de objetos: JNDI Servicios de naming y directory Import javax.naming.*; import java.rmi.*; public class Client { public static void main(string args[]) Throws Exception { // Buscar el Stub através del JNDI Context ctx=new InitialContext(System.getProperties()); Object remoteobject=ctx.lookup( KaixoObj ); // Casting IKaixo ikaixo=(ikaixo)javax.rmi.portableobject.narrow(remoteobject,kaixo.class); System.out.println(ikaixo.iepa( alumnos de iso )); } 26

27 Índice Tecnología utilizada Qué son los EJB s? Desarrollo de un EJB Clasificación de EJB s Los Session Bean Los Entity Bean 27

28 Qué son los Enterprise JavaBeans EJB s: componentes usados como parte de aplicaciones corporativas distribuidas Cada bean encapsula parte de la lógica de negocio de la aplicación Se comunica con gestores de recursos y otro EJB s Accedido por distintos tipos de clientes: EJB s, servlets, clientes de aplicación, etc. En tiempo de ejecución reside en un contenedor EJB: servicios de seguridad, transacción, instalación(deployment), concurrencia y gestión del ciclo de vida. Una aplicación puede tener uno o varios EJB s en uno o varios contenedores EJB 28

29 Instalación típica J2EE Cliente web browser Web container JSP Servlets EJB container JDBC Bases de datos Cliente app. local Cliente Applet Firewall Servlets RMII-IIOP RMI-IIOP JSP Enteprise Beans Enteprise Beans Enteprise Beans Conectores Aplicaciones legadas Sistemas ERP Messaging(EJB 2.0, JMS, EJB 2.1) Servidor J2EE 29

30 Arquitectura Cliente EJB Container Interfaz remota API Transacciones Objeto remoto API Seguridad API BD Servicios Interfaz remota Stub Red Skeleton Aumento de las necesidades en el servidor: Transacciones, Persistencia, Seguridad, Threads,... 30

31 Arquitectura Corba Middleware explícito (anterior a J2EE) EJB Container API Transacciones Cliente Interfaz remota Interfaz remota Objeto remoto API Seguridad API BD Servicios Stub Red Skeleton CORBA: Invocación explícita a los servicios middleware a 31 través de un API dentro del código del objeto remoto

32 Arquitectura Corba Middleware explícito: Ejemplo transfer (Cuenta cuenta1, Cuenta cuenta2, long cantidad) { // 1: Invocar al API del middleware para verificar la seguridad // 2: Invocar al API del middleware para iniciar una transacción // 3: Invocar al API del middleware para cargar las tuplas de la BD 4: eliminar la cantidad de una cuenta y añadirlo a la otra // 5: Invocar al API del middleware para almacenar las tuplas // 6: Invocar al API del middleware para finalizar una transacción } 32

33 Arquitectura Corba Middleware explícito: Desventajas 1. Difícil de escribir: El código está contaminado. Muchas líneas de código no relacionadas con la lógica de negocio. 2. Difícil de mantener: Si se quiere modificar los servicios que utiliza el Bean, se necesita reescribir el código. 3. Difícil de Modificar: Los Vendedores Independientes de Software (ISV) NO ofrecen el código fuente, ya que es su propiedad intelectual. Por lo tanto los cambios en el código no serán posibles directamente. 33

34 Arquitectura J2EE Middleware implícito XML deployment Cliente <transaction> <security>. <data>. EJB Container Interfaz remota Objeto remoto API Transacciones API Seguridad API BD Servicios Interfaz remota Stub Red Skeleton 34

35 Arquitectura J2EE Middleware implícito Cliente EJB Container Objeto remoto Interfaz remota Objeto intercpt Interfaz remota API Transacciones API Seguridad API BD Servicios Interfaz remota Stub Red Skeleton 35

36 Arquitectura Middleware implícito: Arquitectura EJB 1. Escribir el objeto distribuido que contiene únicamente la lógica de negocio. No implementar invocación a los servicios del middleware transfer (Cuenta cuenta1, Cuenta cuenta2, long cantidad) { // 1: eliminar la cantidad de una cuenta y añadirlo a la otra } 2. Declarar los servicios que necesita el objeto distribuido en un fichero separado: fichero descriptor 3. Describir (interfaz) los servicios que exporta el objeto distribuido. 4. Ejecutar el programa suministrado por el proveedor, para que teniendo en cuenta las necesidades del objeto distribuido genere el objeto interceptor 5. El objeto interceptor intercepta la llamada desde el cliente, ejecuta los servicios del middleware que necesita el objeto distribuido y finalmente delega la llamada al objeto distribuido 36

37 Arquitectura Middleware implícito: Ventajas 1. Fácil de escribir: Únicamente se escribe la lógica de la aplicación. Los servicios necesarios se declaran en un fichero de texto. 2. Fácil de mantener: La separación de la lógica de negocio y la lógica del middleware es ortogonal. Modificaciones en el middleware NO implica modificaciones en el código de la aplicación. 3. Fácil de Modificar: Los clientes pueden modificar las necesidades del middleware modificando el fichero descriptor. Por ejemplo, se puede modificar aspectos de seguridad sin modificar el código fuente. 37

38 RMI y EJB s 38

39 Arquitectura completa EJB s 39

40 Desarrollo de un EJB Creación de un EJB Object remoto Client Code, such as Sevlets or Applets 5: Devolución referencia Objeto EJB (Stub) EJB Container/Server 3: Crear un nuevo objeto EJB 1: localizar referencia objeto Home 2: return referencia objeto Home interface Home JNDI Objeto Home 4: Crear objeto EJB Enterprise Beans Servicio Naming (LDAP) interface remota Objeto EJB En la interfaz home se indican los parámetros necesarios (de los métodos constructores) para crear los objetos EJB 40

41 Implementación componente EJB Un componente EJB [Kaixo] se define mediante tres objetos: Interfaz componente (o ejb) [IKaixo.java]: define los métodos del componente accesibles desde el cliente Interfaz home [IKaixoHome.java]: define los métodos de creación y borrado de componentes accesibles desde el cliente Objeto bean [KaixoBean.java]: define la implementación de los métodos del componente y el código de inicialización y borrado de los componentes 41

42 Desarrollo de un componente EJB 1. Escribir las interfaces componente y home 2. Escribir la clase bean con la implementación de los métodos de negocio 3. Crear el descriptor de despliegue ejb-jar.xml 4. Crear el fichero EJB JAR 5. Desplegar el bean en el contenedor 6. Usar el bean desde los clientes 42

43 Desarrollo de un EJB La interfaz remota Indica qué métodos del Bean se exportan Es una interfaz java Descrita por el desarrollador Tiene que extender a javax.ejb.ejbobject javax.ejb.ejbobject extiende a java.rmi.remote. Todo objeto que implementa java.rmi.remote es un objeto remoto que puede ser invocado desde cualquier JVM 43

44 Desarrollo de un EJB La interfaz remota La interfaz con la que opera el cliente cuando quiere invocar al EJB. Es tarea del sistema implementar esta interfaz. El objeto implementado es el objeto EJB, quien delega la invocación al bean. public interface IKaixo extend javax.ejb.ejbobject { public String iepa() throws java.rmi.remoteexception; } 44

45 Desarrollo de un EJB La interfaz Home Esta interfaz tiene métodos para crear/destruir objetos EJB. La implementación del home interface es el home Object y la implementa el sistema public interface IKaixoHome extend javax.ejb.ejbhomeobject { IKaixo create() throws java.rmi.remoteexception, java.ejb.createexception; } 45

46 Desarrollo de un EJB Invocación a un Bean remoto Client Code, such as Sevlets or Applets EJB Container/Server 1: invocar Stub interface Home Objeto Home 6: llamada bean Enterprise Beans interface remota Objeto EJB 5: middleware Transaction service, Security service Persistence service, etc... Interfaz remota 4:invocar al Objeto EJB Stub Red 2: marshall 3: unmarshall Skeleton 46

47 Desarrollo de un EJB Creación de un EJB Object local EJB Container/Server Client Code, such as Sevlets 1: invocar el objeto local Interface local Home Objeto local Home 3: llamada bean Enterprise Beans interface local Objeto local EJB 2: middleware Transaction service, Security service Persistence service, etc... En ocasiones, el cliente se encuentra en la misma máquina que el contenedor de EJB!! 47

48 Desarrollo de un EJB La interfaz local Los clientes locales pueden utilizar esta interfaz para invocar al bean. La mayor diferencia radica en el tratamiento de excepciones public interface IKaixoLocal extend javax.ejb.ejblocalobject { public String iepa() ; } 48

49 Desarrollo de un EJB La interfaz local home Los clientes locales pueden utilizar esta interfaz para invocar al bean. La mayor diferencia radica en el tratamiento de excepciones public interface IKaixoLocalHome extend javax.ejb.ejblocalhome { KaixoLocal create() throws java.ejb.createexception; } 49

50 Desarrollo de un EJB La clase Bean public class KaixoBean implements javax.ejb.sessionbean { private SessionContext ctx; public void ejbcreate() {}; public void ejbremove() {}; public void ejbactivate() {}; public void ejbpassivate() {}; public void setsessioncontext(javax.ejb.sessioncontext ctx){ this.ctx=ctx;} } //Métodos de negocio public String iepa() { return iepa guztioi!!!! ; } 50

51 Desarrollo de un EJB Descriptor deployment independiente Los servicios middleware requeridos por el Bean (XML) - Gestión del bean: Nombre, tipo, home interface - Requisitos de Persistencia: Cómo almacenar los datos - Requisitos Transacionales - Requisitos de Seguridad 51

52 Desarrollo de un EJB Descriptor deployment independiente <ejb-jar> <enterprise-beans> <session> <ejb-name> El nombre del bean <home> El nombre de la interface home <remote> El nombre de la interface remota <local-home> El nombre del la interface local remota <local> El nombre de la interface local <ejb-class> el nombre del la clase del bean (class) <session-type> Si es stateful o stateless <transaction-type>... <session> <enterprise-beans> <ejb-jar> 52

53 Desarrollo de un EJB Descriptor deployment independiente <ejb-jar> <enterprise-beans> <session> <ejb-name> Kaixo </ejb-name> <home> examples.ikaixohome </home> <remote> examples.ikaixo </remote> <local-home> examples.ikaixolocalhome </local-home> <local> examples.ikaixolocal </local> <ejb-class> examples.kaixobean </ejb-class> <session-type> Stateless </session-type> <transaction-type> Container </transaction-type> <session> <enterprise-beans> <ejb-jar> 53

54 Desarrollo de un EJB Descriptor deployment dependiente Describe parámetros no estándar. Depende del servidor de EJBs. Referencia JNDI 54

55 Desarrollo de un EJB El fichero de despliegue. El fichero.jar Interfaces Home Remota Interfaces Home Local Creador fichero JAR Fichero Jar EJB Clases Enterprise Bean Interfaces Object Remota Interfaces Object Local Deployment Descriptor independiente Deployment Descriptor dependiente 55

56 Desarrollo de un EJB Pasos a seguir Escribir los ficheros.java que componen el bean: interfaces local y remoto, interfaces home local y remoto, el propio fichero y las clases adyacentes que sean necesarias Escribir el fichero de deployment Compilar las clases del punto 1 Crear al fichero Ejb-jar utilizando la utilidad jar. Este fichero debe contener el fichero de deployment y los ficheros.class Implantar el fichero ejb-jar Iniciar el contenedor de EJB (servidor) Crear un fichero.java que pruebe si funciona correctamente 56

57 Desarrollo de un EJB Modelo de Objetos Viene con la plataforma Java 2 <<interface>> javax.rmi.remote <<interface>> java.io.serializable <<interface>> javax.ejb.ejblocalobject <<interface>> javax.ejb.ejbobject Viene con la distribución de EJB <<interface>> javax.ejb.ejbhome <<interface>> javax.ejb.ejblocalhome <<interface>> javax.ejb.enterprisebean <<interface>> javax.ejb.sessionbean <<interface>> Kaixo Local Interface <<interface>> Kaixo Remote Interface <<interface>> Kaixo Home Interface <<interface>> Kaixo Local HomeInterface Suministrado por el proveedor del Bean (tenemos que escribirlo) Kaixo Bean Clase Implementación Kaixo EJB Local Object Kaixo EJB Object Kaixo Home Object Kaixo Local Home Object Generado por nosotros utilizando las herramientas del vendedor 57

58 Desarrollo de un EJB El cliente EJB Container/Server Cliente Interface Home 3: Crear nuevo objeto EJB 5: return referencia objeto EJB Objeto Home 6: Invocación método 4: Crear objeto EJB 1: localizar referencia objeto Home 2: return referencia objeto Home interface local Objeto EJB Enterprise Beans JNDI 7: delegar llamada al bean Servicio Naming (LDAP) 58

59 Desarrollo de un EJB El cliente Crear el contexto inicial. Los parámetros iniciales dependen de la plataforma. Localizar la referencia al EJB. Se obtiene una referencia a un objeto Home. Obtener la referencia a un objeto remoto (Remote Interface). Invocar los servicios ofrecidos por el EJB a través de la interfaz remota obtenida. 59

60 Desarrollo de un EJB El código del cliente Import javax.naming.context; import javax.naming.initialcontext; import javax.util.properties; public class KaixoClient { Parámetros de conexión al servidor JNDI public static void main(string[] args) throws Exception { //propiedades JNDI Properties props=system.getproperties(); // Obtener el contexto JNDI inicial (ip, posicion árbol) InitialContext ctx=new InitialContext(props); Conexión con el servidor JNDI 60

61 Desarrollo de un EJB El código del cliente Localización del objeto Home // Casting Object obj=ctx.lookup( KaixoHome ); KaixoHome home=(kaixohome ) javax.rmi.portableremoteobject.narrow( obj, KaixoHome.class); Kaixo kaixo=home.create(); Creación del objeto remoto System.out.println(kaixo.iepa()); } Invocación de los servicios del EJB 61

62 Índice Tecnología utilizada Arquitectura de componentes Desarrollo de un EJB Clasificación de EJB s Los Session Bean Los Entity Bean 62

63 Clasificacion de EJB Session Bean Características Ejecutados en relación a un único cliente Puede manejar datos en una BD subyacente De vida relativamente corta No se garantiza su persistencia en caso de caída del sistema Implementa lógica y/o reglas de negocio Ejemplos: validación tarjeta crédito carrito de la compra 63

64 Clasificacion de EJB Entity Bean Características Representa datos en una base de datos Siempre es transaccional Siempre compartido por múltiples usuarios Existe mientras existan los datos que subyacen Su persistencia es transparente en caso de caída del sistema Encapsula objetos de negocio Ejemplo: control de inventario de productos 64

65 Los Entity-bean Account class AccountID ownername balance 1 Ray Combs Bob Barker 1500 String accountid String ownername double balance deposit(amount) withdraw(amount) 3 Monty Haul 2750 Tabla Account Base de datos Account Instance accountid=1 ownername=ray Combs balance=

66 Los Entity Bean Account class String accountid String ownername double balance deposit(amount) withdraw(amount) Cada objeto se caracteriza por una clave El desarrollador del Bean únicamente se encarga de implementar los métodos deposit y withdraw El sistema se encargará de manera automática de actualizar la BD cuando haya habido alguna operación que haya modificado alguna de las variables del objeto cuenta 66

67 Desarrollo de EJB s Los Session Beans 67

68 Índice Clasificación de los Session Bean Stateless y Stateful Desarrollo de un Session Bean Stateless y Stateful 68

69 Introducción a los Session Beans Tipos de Session Bean Sin estado (stateless EJBs) Completamente transitorio Mera pieza de maquinaria de negocio No retiene información entre llamadas Con estado (stateful EJBs) Mantiene estado conversacional con el cliente Extensión lógica en el servidor de la aplicación cliente Pueden participar en transacciones Accedidos a través de su interfaz remota 69

70 Ejemplo I: Stateless bean Bean sin estado EJB Container/Server Interface Home Objeto Home isloginvalid(login, passwd) Enterprise Beans Gestión de Passwords isloginvalid(login, passwd) Interface Remota isloginvalid(login, passwd) Objeto EJB 70

71 Ejemplo I: Stateless bean Bean sin estado 4 partes requeridas al definir un bean: La interfaz remota. Extiende javax.ejb.ejbobject La interfaz Home. Extiende javax.ejb.ejbhome La definición de la clase del Bean Meta-data (descriptores y otra info. de configuración) 71

72 Ejemplo I: Stateless bean La interfaz remota Creación de la interfaz remota Extiende javax.ejb.ejbobject import javax.ejb.*; import java.rmi.*; public interface PasswordManager extends EJBObject { } public Boolean isloginvalid(string login, String password) throws java.rmi.remoteexception; Esta interfaz define los servicios ofrecidos por el EJB. Todos los parámetros deben ser serializables 72

73 Ejemplo I: Stateless bean La interfaz home Creación de la interfaz home Extiende javax.ejb.ejbhome import javax.ejb.*; import java.rmi.*; public interface PasswordManagerHome extends EJBHome { PasswordManager create() throws CreateException, RemoteException } Los métodos create(): Invocan a los métodos ejbcreate() de la clase bean Deben corresponderse en número y tipo de argumentos a los métodos ejbcreate() de la clase bean. En lugar de devolver void devuelven una instancia de la interfaz remota Lanza cualquier excepción que lance sus homónimos en la clase bean, y debe lanzar javax.ejb.createexception Los métodos remove() no deben ser sobreescritos. 73

74 La interfaz home Relación entre create() y ejbcreate() EJB Container/Server Cliente 1: create 6: return referencia objeto EJB Objeto Home 2:ejbCreate() 4: return id objeto Session Bean Instance 5: Crear objeto EJB(id objeto) Objeto EJB 74

75 Ejemplo I: Stateless bean La clase Bean Debe implementar javax.ejb.sessionbean, que proporciona los métodos: import javax.ejb.*; import java.rmi.*; public class PasswordManagerBean implements SessionBean { public boolean isloginvalid(string login, String password) throws RemoteException {} public void ejbcreate() throws RemoteException {} public void ejbactivate() throws RemoteException {} public void ejbpassivate() throws RemoteException {} public void ejbremove() throws RemoteException {} public void setsessioncontext (SessionContext ctx) throws RemoteException {} } Estos métodos son invocados por el contenedor de EJBs 75

76 Gestion de los Beans Stateless Bean EJB Container/Server Cliente Stateless Bean Pool Interface Remota Bean Bean Objeto EJB Invoke() Bean Bean Se tiene un conjunto de Beans, y los clientes pueden reutilizar los Beans 76

77 Ejemplo I: Stateless bean La clase Bean Creación de la clase bean (II) Además se deben implementar uno o más métodos ejbcreate(): Es el mecanismo de inicialización del EJB. Puede estar parametrizado. También debe implementar uno o más métodos de negocio: Debe implementar los servicios de la interfaz remota import javax.ejb.*; import java.rmi.*; public class PasswordManagerBean implements SessionBean {... public boolean isloginvalid(string login, String password) throws java.rmi.remoteexception; { //Pedir una conexion JDBC al Pool de conexiones. DataSource ds = initialcontext.lookup( java:comp/env/jdbc/passwords ); Connection conn=ds.getconnection();... //Comprobar si existe ese login con ese password // boolean passvalid=.. return passvalid; } }

78 Ejemplo II: Stateful bean La clase Bean EJB Container/Server Interface Home Objeto Home Gestión de Passwords Interface Remota isloginvalid(passwd) changepass(oldpass, newpass) Enterprise Beans isloginvalid(passwd) changepass(oldpass,newpass) Objeto EJB isloginvalid(passwd) changepass(oldpass, newpass) 78

79 Ejemplo II: Stateful bean Bean con estado 4 partes requeridas al definir un bean: La interfaz remota. Extiende javax.ejb.ejbobject La interfaz Home. Extiende javax.ejb.ejbhome La definición de la clase del Bean Meta-data (descriptores y otra info. de configuración) 79

80 Ejemplo II: Stateful bean La interfaz remota Creación de la interfaz remota Extiende javax.ejb.ejbobject import javax.ejb.*; import java.rmi.*; public interface PasswordManager extends EJBObject { public Boolean isloginvalid(string password) throws java.rmi.remoteexception; public Boolean changepass(string oldpass, String new Pass) throws java.rmi.remoteexception; } Esta interfaz define los servicios ofrecidos por el EJB. Todos los parámetros deben ser serializables 80

81 Ejemplo II: Stateful bean La interfaz home Creación de la interfaz home Extiende javax.ejb.ejbhome import javax.ejb.*; import java.rmi.*; public interface PasswordManagerHome extends EJBHome { PasswordManager create() throws CreateException, RemoteException PasswordManager create(string login) throws CreateException, RemoteException } Los métodos create(): Los metodos create invocan a los métodos ejbcreate() de la clase bean. Deben corresponderse en número y tipo de argumentos a los métodos ejbcreate() de la clase bean. En lugar de devolver void devuelven una instancia de la interfaz remota Lanza cualquier excepción que lance sus homónimos en la clase bean, y debe lanzar javax.ejb.createexception Los métodos remove() no deben ser sobreescritos. 81

82 Ejemplo II: Stateful bean La clase Bean Debe implementar javax.ejb.sessionbean, que proporciona los métodos: import javax.ejb.*; import java.rmi.*; public class PasswordManagerBean implements SessionBean { String name; public boolean isloginvalid(string password) throws RemoteException {} public void ejbcreate(string name) throws RemoteException {} public void ejbcreate() throws RemoteException {} public void ejbactivate() throws RemoteException {} public void ejbpassivate() throws RemoteException {} public void ejbremove() throws RemoteException {} public void setsessioncontext (SessionContext ctx) throws RemoteException {} } Estos métodos son invocados por el contenedor de EJBs 82

83 Ejemplo II: Stateful bean La clase Bean Creación de la clase bean (II) Además se deben implementar uno o más métodos ejbcreate(): Es el mecanismo de inicialización del EJB. Puede estar parametrizado. También debe implementar uno o más métodos de negocio: Debe implementar los servicios de la interfaz remota import javax.ejb.*; import java.rmi.*; public class PasswordManagerBean implements SessionBean { String login; public void ejbcreate(string login) { this.login=login; } public Boolean isloginvalid( String password) throws java.rmi.remoteexception { //Pedir una conexion JDBC al Pool de conexiones. DataSource ds = initialcontext.lookup( java:comp/env/jdbc/passwords ); Connection conn=ds.getconnection();... //Comprobar si existe el login con ese password // Boolean passvalid=.. return passvalid; 83 }...}

Aplicaciones Web Servidor

Aplicaciones Web Servidor Reutilización de software A nivel de clase: Clases y algoritmos JGL A nivel de diseño Patrones de diseño A nivel de arquitectura Arquitectura J2EE 2 Aplicaciones Web Servidor Introducción a la arquitectura

Más detalles

Sistemas de Operación 3

Sistemas de Operación 3 Sistemas de Operación 3 Los EJBs proporcionan un modelo de componentes distribuido estándar del lado del servidor. El objetivo de los EJBs es dotar al programador de un modelo que le permita abstraerse

Más detalles

Enterprise JavaBeans Sesión 1: Características básicas de EJB

Enterprise JavaBeans Sesión 1: Características básicas de EJB Especialista en Aplicaciones y Servicios Web con Java Enterprise Enterprise JavaBeans Sesión 1: Características básicas de EJB Enterprise JavaBeans 2003-2004 Depto. Ciencia Computación e IA Características

Más detalles

Componentes Distribuidos EJBs. Ing. Cesar Julio Bustacara Medina

Componentes Distribuidos EJBs. Ing. Cesar Julio Bustacara Medina Componentes Distribuidos EJBs Ing. Cesar Julio Bustacara Medina Introducción La Clase del Bean Contiene la lógica del Enterprise Bean. Es una clase Java pública, que implementa los métodos de negocios

Más detalles

Parte II: Java 2 Enterprise Edition. Enterprise JavaBeans. Ignacio Ramos Zapata

Parte II: Java 2 Enterprise Edition. Enterprise JavaBeans. Ignacio Ramos Zapata Parte II: Java 2 Enterprise Edition Enterprise JavaBeans Ignacio Ramos Zapata Departamento de Ingeniería Telemática Universidad Carlos III de Madrid irzapata@it.uc3m.es Introducción a Enterprise JavaBeans

Más detalles

'HVDUUROORGH$SOLFDFLRQHV

'HVDUUROORGH$SOLFDFLRQHV 'HVDUUROORGH$SOLFDFLRQHV FRQ-(( $SOLFDFLRQHV'LVWULEXLGDV0XOWLFDSD &RQWHQLGR Plataforma J2EE Aplicaciones Distribuidas multicapa Arquitectura Multicapa Componentes J2EE Componentes de Clientes: aplicaciones

Más detalles

4 Encuentro Internacional de Computación Aplicada

4 Encuentro Internacional de Computación Aplicada 4 Encuentro Internacional de Computación Aplicada Arquitectura de Objetos Distribuidos utilizando EJBs Omar Gómez omar@cuci.udg.mx Agenda Arquitectura de Objetos Distribuidos Arquitectura J2EE Componentes

Más detalles

Servlets. Contenedor EJB JSP. Enterprise Beans. Enterprise Beans. Enterprise Beans. Messaging (EJB 2.0: JMS, EJB 2.1: +JAXM, )

Servlets. Contenedor EJB JSP. Enterprise Beans. Enterprise Beans. Enterprise Beans. Messaging (EJB 2.0: JMS, EJB 2.1: +JAXM, ) Introducción a los EJBs Mario Muñoz Organero Departamento de Ingeniería Telemática http://www.it.uc3m.es/mario Panorámica JEE Contenedor Web EIS Cliente Web Browser Cliente Servicios Aplicac. Applet, Cliente

Más detalles

5.2 Introducción a EJB

5.2 Introducción a EJB 5.2 Introducción a EJB Java RMI como tecnología para la construcción de aplicaciones empresariales (1) Aspectos positivos Permite separar físicamente la vista y el controlador del modelo de manera sencilla

Más detalles

Enterprise JavaBeans

Enterprise JavaBeans EJBs Enterprise JavaBeans Que son los EJBs? Enterprise JavaBeans (EJB) es una arquitectura de componentes de servidor que simplifica el proceso de construcción de aplicaciones de componentes empresariales

Más detalles

Curso de Sistemas Distribuidos Facultad de Informática

Curso de Sistemas Distribuidos Facultad de Informática Componentes en J2EE Curso de Sistemas Distribuidos Facultad de Informática Juan Pavón Mestras Dep. Sistemas Informáticos y Programación Universidad Complutense Madrid Componentes software Se habla de ellos

Más detalles

JAVA ENTERPRISE EDITION (J2EE) ARQUITECTURA TECNOLOGÍAS (1/2) (L1)

JAVA ENTERPRISE EDITION (J2EE) ARQUITECTURA TECNOLOGÍAS (1/2) (L1) TECNOLOGÍAS (1/2) (L1) EJB ( Enterprise Java Beans ) JSP ( Java Server Pages ) JNDI ( Java Naming and Directory Interface ) JDBC ( Java Data Base Connectivity ) Java Mail JSF ( Java Server Faces ) TECNOLOGÍAS

Más detalles

Introducción a los EJBs

Introducción a los EJBs Introducción a los EJBs Mario Muñoz Organero Departamento de Ingeniería Telemática http://www.it.uc3m.es/mario Panorámica de un Servidor de Información El modelo de aplicaciones J2EE se basa en una arquitectura

Más detalles

Software de Comunicaciones I.T.T. Especialidad Telemática Escuela Politécnica Superior Universidad Carlos III de Madrid

Software de Comunicaciones I.T.T. Especialidad Telemática Escuela Politécnica Superior Universidad Carlos III de Madrid Duración de los problemas: 1 hora 30 minutos. Duración total del examen: 2 horas 30 minutos. Software de Comunicaciones I.T.T. Especialidad Telemática Escuela Politécnica Superior Universidad Carlos III

Más detalles

Session Beans y Entity Beans. Contenido

Session Beans y Entity Beans. Contenido Session Beans y Entity Beans Ignacio Ramos Zapata Departamento de Ingeniería Telemática Universidad Carlos III de Madrid irzapata@it.uc3m.es Contenido Caso de estudio Gestión de recursos Pooling de instancias

Más detalles

Aplicaciones web construidas a base de componentes:

Aplicaciones web construidas a base de componentes: Java EE Aplicaciones Web/Sistemas Web Juan Pavón Mestras Dep. Ingeniería del Software e Inteligencia Artificial Facultad de Informática Universidad Complutense Madrid Material bajo licencia Creative Commons

Más detalles

Desarrollo de Componentes de Negocio con Tecnología

Desarrollo de Componentes de Negocio con Tecnología Desarrollo de Componentes de Negocio con Tecnología Empresarial Java Beans Modalidad Online Horario Flexible Descuento Alumnos Duración 180 horas Nivel Superior Subvención Empresas Descripción Detallada

Más detalles

TEMA 54 La arquitectura JEE

TEMA 54 La arquitectura JEE TEMA 54 La arquitectura JEE Índice 1 Introducción... 2 1.1 Tecnología JAVA 3 1.2 Las plataformas Java 3 2 La plataforma JEE... 4 2.1 Modelo distribuido multicapa 4 2.2 Gestión de componentes basada en

Más detalles

Nivel de negocio en J2EE: Enterprise Java Beans

Nivel de negocio en J2EE: Enterprise Java Beans UNIVERSIDAD CARLOS III DE MADRID DEPARTAMENTO DE INGENIERÍA TELEMÁTICA SOFTWARE DE COMUNICACIONES (I.T.T.T) Nivel de negocio en J2EE: Enterprise Java Beans Pablo Basanta Val Florina Almenares Mendoza Basado

Más detalles

Índice del tema. Entity yy y Session EJBs) Mario Muñoz Organero Departamento de Ingeniería Telemática

Índice del tema. Entity yy y Session EJBs) Mario Muñoz Organero Departamento de Ingeniería Telemática EJBs (comprendiendo las Entity yy y Session EJBs) Mario Muñoz Organero Departamento de Ingeniería Telemática http://www.it.uc3m.es/mario Índice del tema Recordatorio: Qué son los Enterprise Java Beans?

Más detalles

TEMA 5. Otras arquitecturas distribuidas III. Otros entornos de objetos distribuidos

TEMA 5. Otras arquitecturas distribuidas III. Otros entornos de objetos distribuidos TEMA 5. Otras arquitecturas distribuidas III. Otros entornos de objetos distribuidos III. Otros entornos de objetos distribuidos 1. Problemas de CORBA 2. Java Enterprise Edition 1. EJB 2. Servidor de aplicaciones

Más detalles

Java EE Enterprise Beans (EJB)

Java EE Enterprise Beans (EJB) Java EE Enterprise Beans (EJB) Aplicaciones Web/Sistemas Web Juan Pavón Mestras Dep. Ingeniería del Software e Inteligencia Artificial Facultad de Informática Universidad Complutense Madrid Material bajo

Más detalles

JavaEE. www.javasoft.com

JavaEE. www.javasoft.com JavaEE Java Enterprise Edition www.javasoft.com Por qué Java en el servidor? Ventajas Independencia de la plataforma portabilidad Gran conjunto de APIs Reusabilidad y modularidad Seguro en la ejecución

Más detalles

RMI. Aplicaciones Distribuidas

RMI. Aplicaciones Distribuidas RMI Aplicaciones Distribuidas Contenido Objetos Distribuidos y RMI. Interface Remota. Clase Implementación. Referencias Remotas. Registro RMI. Paso de parámetros. Descarga dinámica de código. Desarrollo

Más detalles

Java RMI. Sistemas distribuidos

Java RMI. Sistemas distribuidos Java RMI Sistemas distribuidos Entornos orientados a objetos Tendencia actual hacia sistemas compuestos por un conjunto de objetos que interactúan entre sí. Un programa solicita servicios invocando los

Más detalles

Enterprise Java Beans. JBoss AS. Ronier Rodríguez

Enterprise Java Beans. JBoss AS. Ronier Rodríguez Enterprise Java Beans JBoss AS Ronier Rodríguez 06-40233 Enterprise Java Beans. Preludio - En los 60, grandes maquinas usadas por organizaciones gigantes. - En los 70, Minicomputadores y Timesharing. Aún

Más detalles

Caso J2EE. Necesidades del negocio. Arquitectura Luther

Caso J2EE. Necesidades del negocio. Arquitectura Luther Caso J2EE Grupo de Construcción de Software Facultad de Ingeniería Universidad de los Andes Necesidades del negocio Describa el objetivo funcional del sistema que desea Inmedius Enumere los RNF que debe

Más detalles

FSD Práctica Invocación Remota: JavaRMI. Estudio Previo. Información

FSD Práctica Invocación Remota: JavaRMI. Estudio Previo. Información FSD Práctica Invocación Remota: JavaRMI Tipo de entrega: por grupos de prácticas Fecha límite: sesión de laboratorio Lugar: Campus Digital Comentario: No hay que entregar el estudio previo Objetivo de

Más detalles

5.4 Caso de estudio: diseño e implementación de la capa modelo de MiniPortal con EJB. Tipos de EJBs y patrones usados

5.4 Caso de estudio: diseño e implementación de la capa modelo de MiniPortal con EJB. Tipos de EJBs y patrones usados 5.4 Caso de estudio: diseño e implementación de la capa modelo de MiniPortal con EJB. Tipos de EJBs y patrones usados Introducción Qué tipos de EJBs ilustra MiniPortal? Entity Beans CMP (UserProfile) SLSBs

Más detalles

Guía del Curso Analista Programador Java: Business Apps Expert

Guía del Curso Analista Programador Java: Business Apps Expert Guía del Curso Analista Programador Java: Business Apps Expert Modalidad de realización del curso: Número de Horas: Titulación: Online 600 Horas Diploma acreditativo con las horas del curso OBJETIVOS UML

Más detalles

Tema 5. Plataforma Java EE

Tema 5. Plataforma Java EE Tema 5. Plataforma Java EE SCS Sistemas Cliente/Servidor 4 o informática http://ccia.ei.uvigo.es/docencia/scs septiembre 2011 FJRP, FMBR 2008-2011 ccia SCS 5.1 Introducción a Java EE Java EE (Java Enterprise

Más detalles

Modelo de Objetos Distribuidos

Modelo de Objetos Distribuidos Remote Method Invocation Modelo de Objetos Distribuidos Un objeto remoto es un objeto cuyos métodos pueden ser invocados desde otra máquina virtual de java, potencialmente en un host diferente. Modelo

Más detalles

Oracle 10g: Creación de Aplicaciones J2EE

Oracle 10g: Creación de Aplicaciones J2EE Oracle University Contacte con nosotros: 902 302 302 Oracle 10g: Creación de Aplicaciones J2EE Duración: 5 Días Lo que aprenderá Este curso enseña a los desarrolladores a crear aplicaciones J2EE mediante

Más detalles

Tema 1. Introducción a Java EE

Tema 1. Introducción a Java EE Objetivos del tema Propiedades de las aplicaciones empresariales El Modelo Cliente/Servidor Presentar la Plataforma Java Presentar Java EE y otras tecnologías horizontales Tema 1. Introducción a Java EE

Más detalles

Invocación de métodos remotos en Java: JAVA - RMI

Invocación de métodos remotos en Java: JAVA - RMI Diseño Y Aplicaciones de Sistemas Distribuidos Invocación de métodos remotos en Java: JAVA - RMI Joan Vila DISCA / UPV Departament d Informàtica de Sistemes i Computadors Universitat Politècnica de València

Más detalles

RMI. Ingeniería del Software II Curso 2009/2010.

RMI. Ingeniería del Software II Curso 2009/2010. RMI Ingeniería del Software II Curso 2009/2010 Sergio Ilarri Artigas Sergio Ilarri Artigas silarri@unizar.es Índice Introducción Stubs y Skeletons (rmic) Objetos Remotos y Objetos Serializables: Interfaz

Más detalles

Session Beans y Entity Beans Avanzado. Caso de estudio: Entity Bean

Session Beans y Entity Beans Avanzado. Caso de estudio: Entity Bean Session Beans y Entity Beans Avanzado Ignacio Ramos Zapata Departamento de Ingeniería Telemática Universidad Carlos III de Madrid irzapata@it.uc3m.es Caso de estudio: Entity Bean Ciclo de vida Ejemplos

Más detalles

Panorámica de la asignatura

Panorámica de la asignatura Arquitecturas típicas. Mario Muñoz Organero Departamento de Ingeniería Telemática http://www.it.uc3m.es/mario Panorámica de la asignatura RED Comunicaciones Servidores información Intercambio de datos

Más detalles

Enterprise JavaBeans 3. Aplicaciones Distribuidas

Enterprise JavaBeans 3. Aplicaciones Distribuidas Enterprise JavaBeans 3 Aplicaciones Distribuidas Contenido Introducción Motivación Características básicas Servicios integrados en EJB 3 Ejemplo Hola Mundo Inyección de dependencia Tipos de EJB 3 Conclusiones

Más detalles

Enterprise JavaBeans

Enterprise JavaBeans Enterprise Java Beans y JBoss Enterprise JavaBeans Es una de las API que forman parte del estándar de construcción de aplicaciones empresariales J2EE (ahora JEE 5.0) de Oracle Corporation (inicialmente

Más detalles

JEE Enterprise Java Beans

JEE Enterprise Java Beans JEE Enterprise Java Beans Sistemas Distribuidos Reny Alvarado. Caracas, Febrero 2007 Aspectos a tratar Java. JEE Java Platform, Enterprise Edition Modelo de Aplicación de JavaEE Arquitectura multicapas

Más detalles

Desarrollo de Sistemas Software Basados en Servicios y Componentes

Desarrollo de Sistemas Software Basados en Servicios y Componentes Desarrollo de Sistemas Software Basados en Servicios y Componentes Bloque Docente SERVICIOS WEB Parte 2 Portada Escuela Superior de Ingeniería (ESI) Universidad de Almería Índice Visualización WSDL (servicios

Más detalles

Tema 5. Plataforma Java EE

Tema 5. Plataforma Java EE Tema 5. Plataforma Java EE SCS Sistemas Cliente/Servidor 4 o informática http://ccia.ei.uvigo.es/docencia/scs enero 2009 FJRP, FMBR 2008/09 ccia SCS 5.1 Introducción a Java EE Java EE (Java Enterprise

Más detalles

Introducción al Desarrollo de Aplicaciones Empresariales

Introducción al Desarrollo de Aplicaciones Empresariales Introducción al Desarrollo de Aplicaciones Empresariales Definición Java 2 Enterprise Edition: plataforma de desarrollo de aplicaciones para empresas, basado en EJBs. EJB (Enterprise Java Beans): especificación

Más detalles

Interacción entre Aplicaciones: objetos distribuidos e invocación remota

Interacción entre Aplicaciones: objetos distribuidos e invocación remota Interacción entre Aplicaciones: objetos distribuidos e invocación remota En la anterior práctica se ha visto cómo extender la funcionalidad de un servidor web incorporando servlets que atienden peticiones

Más detalles

Sistemas Distribuidos Java RMI (Remote Method Invocation) Alberto Lafuente Mikel Larrea Dpto. ATC, UPV/EHU

Sistemas Distribuidos Java RMI (Remote Method Invocation) Alberto Lafuente Mikel Larrea Dpto. ATC, UPV/EHU Sistemas Distribuidos Java RMI (Remote Method Invocation) Alberto Lafuente Mikel Larrea Dpto. ATC, UPV/EHU Contenido Interfaz Implementación Servidor Cliente Puesta en marcha de la aplicación: Compilador

Más detalles

[CASI v.0109] Pág. 1

[CASI v.0109] Pág. 1 I. DATOS INFORMATIVOS Carrera Especialidad Curso Código Ciclo : Quinto Requisitos Duración Horas Semana : 08 horas Versión : v.0109 II. SUMILLA : COMPUTACIÓN E INFORMATICA : Ingeniería de Software : Lenguaje

Más detalles

JAVA RMI: ESTRUCTURA INTERNA RMI

JAVA RMI: ESTRUCTURA INTERNA RMI Grupo de Arquitectura de Computadores, Comunicaciones y Sistemas Desarrollo de Aplicaciones Distribuidas AUTORES: Alejandro Calderón Mateos Javier García Blas David Expósito Singh Laura Prada Camacho Departamento

Más detalles

Técnico Superior en Programación con Java SE Standard Edition

Técnico Superior en Programación con Java SE Standard Edition Código: M087_04 Técnico Superior en Programación con Java SE Standard Edition Modalidad: Distancia Duración: 120 horas Objetivos: Este pack de materiales formativos proporcionará al alumnado la base que

Más detalles

Curso: Programación con JAVA SE Estándar Edition.

Curso: Programación con JAVA SE Estándar Edition. Curso: Programación con JAVA SE Estándar Edition. Código: 1062 Familia Profesional: Programación. Acreditación: Formación reconocida a través de vías no formales Modalidad: Distancia Duración: 150 horas

Más detalles

Remote Method Invocation (RMI)

Remote Method Invocation (RMI) Remote Method Invocation (RMI) Metas La meta principal de los diseñadores de RMI fue la de permitir a los programadores el desarrollo de programas distribuidos en JAVA, usando la misma sintáxis y semántica

Más detalles

Magister en Ingeniería de Software

Magister en Ingeniería de Software Magister en Ingeniería de Software Universidad Nacional de La Plata Facultad de Informática Tesis Migración hacia un modelo de persistencia orientado a objetos Desarrollada por Nelson O. Di Grazia Dirigida

Más detalles

A. Goñi, J. Ibáñez, J. Iturrioz, J.A. Vadillo OCW 2013

A. Goñi, J. Ibáñez, J. Iturrioz, J.A. Vadillo OCW 2013 4.3: Computación distribuida: Java RMI A. Goñi, J. Ibáñez, J. Iturrioz, J.A. Vadillo OCW 2013 Indice RMI: Introducción Construcción de aplicaciones RMI Dfii Definir Interfaz remota Implementar interfaz

Más detalles

Programa Formativo. Código: Curso: Programación con JAVA 8 SE Standard Edition Modalidad: ONLINE Duración: 120h.

Programa Formativo. Código: Curso: Programación con JAVA 8 SE Standard Edition Modalidad: ONLINE Duración: 120h. Código: 16630 Curso: Programación con JAVA 8 SE Standard Edition Modalidad: ONLINE Duración: 120h. Objetivos Java es un lenguaje de programación con el que podemos realizar cualquier tipo de desarrollo.

Más detalles

Objetos Distribuidos

Objetos Distribuidos Objetos Distribuidos Objetos Distribuidos Conceptos Estado: encapsula los datos Métodos: operaciones sobre los datos Interfaz: se utiliza para la disponibilidad de los métodos El Estado y la Interfaz se

Más detalles

JAVA EE 5. Arquitectura, conceptos y ejemplos.

JAVA EE 5. Arquitectura, conceptos y ejemplos. JAVA EE 5. Arquitectura, conceptos y ejemplos. INTRODUCCIÓN. MODELO DE LA APLICACIÓN JEE5. El modelo de aplicación Java EE define una arquitectura para implementar servicios como lo hacen las aplicaciones

Más detalles

5 Aplicaciones empresariales con tecnología java EE.

5 Aplicaciones empresariales con tecnología java EE. 5 Aplicaciones empresariales con tecnología java EE. Esta tesis aborda la creación de una aplicación empresarial, pero, a qué se refiere el término de aplicación empresarial? En esencia, las aplicaciones

Más detalles

1. Visión general de RMI

1. Visión general de RMI 1. Visión general de RMI Java RMI permite al programador ejecutar métodos de objetos remotos utilizando la misma semántica que si fueran invocaciones locales (Véase Figura 1). Máquina Local (Cliente) Máquina

Más detalles

Guía del Curso Especialista TIC en Programación con JAVA 8 SE Standard Edition

Guía del Curso Especialista TIC en Programación con JAVA 8 SE Standard Edition Guía del Curso Especialista TIC en Programación con JAVA 8 SE Standard Edition Modalidad de realización del curso: Titulación: A distancia y Online Diploma acreditativo con las horas del curso OBJETIVOS

Más detalles

Diseño de la Capa de Negocio. Aplicaciones Distribuidas

Diseño de la Capa de Negocio. Aplicaciones Distribuidas Diseño de la Capa de Negocio Aplicaciones Distribuidas Motivación Motivación: Implantar un modelo UML (diagramas de clases y colaboraciones) de una aplicación empresarial. Solución:è Enterprise JavaBeans

Más detalles

COMPONENTES Y CONTENEDORES. Ingeniería de Software II

COMPONENTES Y CONTENEDORES. Ingeniería de Software II COMPONENTES Y CONTENEDORES Ingeniería de Software II Motivación Los componentes son paquetes de software o módulos que encapsulan un conjunto de funciones similares. Estos componentes viven dentro de un

Más detalles

Invocación de Métodos Remotos: Prácticas de Laboratorio

Invocación de Métodos Remotos: Prácticas de Laboratorio Invocación de Métodos Remotos: Prácticas de Laboratorio XIII Jornadas de Enseñanza Universitaria de la Informática Teruel, 16-18 de julio de 2007 Coromoto León Hernández, Gara Miranda Valladares (cleon

Más detalles

Creación de una aplicación para JBOSS

Creación de una aplicación para JBOSS Creación de una aplicación para JBOSS Requerimientos: Se debe instalar JBOSS junto con Tomcat, JBuilder 5 Personal y MagicDraw UML 5.0 beta con la conexión a JBuilder. JBOSS con Tomcat se puede bajar de

Más detalles

PRÁCTICA 3: COMPONENTES. Javier Sánchez Pérez Arquitectura del Software Grado en Informática

PRÁCTICA 3: COMPONENTES. Javier Sánchez Pérez Arquitectura del Software Grado en Informática PRÁCTICA 3: COMPONENTES Javier Sánchez Pérez Arquitectura del Software Grado en Informática Contenidos Java EE Enterprise Java Beans Stateless Session Beans Stateful Session Beans Singleton Session Beans

Más detalles

Ingeniería del Software Arquitectura Física en 3 niveles

Ingeniería del Software Arquitectura Física en 3 niveles Introducción En este laboratorio desplegaremos en 3 niveles físicos una aplicación que verifica si una cuenta y un password son correctos, basada en la que fue presentada en el laboratorio Separación entre

Más detalles

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio Modalidad: Online y Titulación acredidatada por la Comisión Internacional de Formación de la UNESCO Postgrado en Servicios Java.

Más detalles

Arquitecturas Empresariales y la plataforma J2EE

Arquitecturas Empresariales y la plataforma J2EE UNIVERSIDAD CARLOS III DE MADRID DEPARTAMENTO DE INGENIERÍA TELEMÁTICA SOFTWARE DE COMUNICACIONES (I.T.T.T) Arquitecturas Empresariales y la plataforma J2EE Pablo Basanta Val Florina Almenares Mendoza

Más detalles

Invocación remota de métodos. Jorge Iván Meza Martínez

Invocación remota de métodos. Jorge Iván Meza Martínez Invocación remota de métodos Jorge Iván Meza Martínez jimezam@gmail.com Especialización en Gestión de Redes de Datos Universidad Nacional de Colombia Sede Manizales 1/58 Contenidos Capas de middleware

Más detalles

Java RMI. Sistemas Distribuidos Rodrigo Santamaría

Java RMI. Sistemas Distribuidos Rodrigo Santamaría + Java RMI Sistemas Distribuidos Rodrigo Santamaría RMI Java RMI 2 + RMI 3 Remote Method Invocation: middleware para que un objeto que se ejecuta en una JVM use métodos de otro objeto que se ejecuta en

Más detalles

TESIS QUE PRESENTAN LOS ALUMNOS

TESIS QUE PRESENTAN LOS ALUMNOS UNIDAD IZTAPALAPA DIVISION DE CIENCIAS BASICAS E INGENIERIA TESIS QUE PRESENTAN LOS ALUMNOS GALICIA ORTEGA ROSALBA MATRICULA 97215457 MUJICA MOTA CARLOS MATRICULA 97219515 PARA LA OBTENCION DEL GRADO DE

Más detalles

Tema 3. Plataforma Java EE

Tema 3. Plataforma Java EE Tema 3. Plataforma Java EE DAGSS Diseño de Arquitecturas de Grandes Sistemas Software 4 o Grado Ing. Informática http://ccia.ei.uvigo.es/docencia/dagss noviembre 2014 FJRP 2014 DAGS 3.1 Introducción a

Más detalles

Código Fuente. Creamos en C:\ una carpeta para ubicar el código fuente del servidor. En mi caso, he creado una carpeta denominada rmi4

Código Fuente. Creamos en C:\ una carpeta para ubicar el código fuente del servidor. En mi caso, he creado una carpeta denominada rmi4 EL EJEMPLO El proceso servidor provoca un eco de la entrada de teclado enviada por el proceso cliente. Por sencillez, ejecutaremos tanto el servidor como el cliente en la máquina local. El sistema operativo

Más detalles

Experto en Desarrollo de Componentes de Negocio con Tecnología Empresarial Java Beans

Experto en Desarrollo de Componentes de Negocio con Tecnología Empresarial Java Beans Experto en Desarrollo de Componentes de Negocio con Tecnología Empresarial Java Beans titulación de formación continua bonificada expedida por el instituto europeo de estudios empresariales Experto en

Más detalles

El servicio de echo en Java-RMI

El servicio de echo en Java-RMI PRÁCTICA 3 El servicio de echo en Java-RMI E l objetivo de esta práctica es crear y ejecutar una aplicación cliente servidor echo basada en java-rmi. La práctica tiene dos partes: La primera parte implementa

Más detalles

RMI [Remote Method Invocation]

RMI [Remote Method Invocation] RMI [Remote Method Invocation] Cuando utilizamos sockets, hemos de preocuparnos de cómo se transmiten físicamente los datos entre los extremos de una conexión (a nivel de bytes, ya que usamos los streams

Más detalles

Llamada a procedimientos remotos. Programación en Red, Tema 3: RMI

Llamada a procedimientos remotos. Programación en Red, Tema 3: RMI Tema 3: Programación en Red, RMI 1 Llamada a procedimientos remotos 2 Previo: Objetos e interfaces en JAVA Object 1 Object 2 Interface 1 Data m1 m2 m3 implementation { of methods public class Client {

Más detalles

Tema 2: Programación en Red, RMI

Tema 2: Programación en Red, RMI Llamada a procedimientos remotos Tema 2: Programación en Red, RMI 1 2 Previo: Objetos e interfaces en JAVA Object 1 public class Client { private Client() { public static void main(string[] args) { Hello

Más detalles

CURSO. Programación web JAVA JEE. Civil, sistemas, diseño

CURSO. Programación web JAVA JEE. Civil, sistemas, diseño CURSO Programación web JAVA JEE Civil, sistemas, diseño Bienvenido, Curso Programación web JAVA JEE Presentación Java es una tecnología para el desarrollo de software que por tener carácter de software

Más detalles

Java EE 6: Desarrollo de componentes de negocio con JMS y EJBs

Java EE 6: Desarrollo de componentes de negocio con JMS y EJBs Oracle University Contact Us: 001-855-844-3881 Java EE 6: Desarrollo de componentes de negocio con JMS y EJBs Duration: 4 Days What you will learn Esta capacitación Java EE 6: Desarrollo de componentes

Más detalles

Java RMI Remote Method Invocation. Invocación Remota de Métodos en Java

Java RMI Remote Method Invocation. Invocación Remota de Métodos en Java Java RMI Remote Method Invocation Invocación Remota de Métodos en Java Contenido Introducción Implementación Diseño de la interfaz remota. Implementación de la interfaz remota. Obtención de las clases

Más detalles

Introducción. 50,SURSRUFLRQDFRPXQLFDFLyQUHPRWDHQWUHSURJUDPDVHVFULWRVHQHOOHQJXDMHGH SURJUDPDFLyQ-DYD

Introducción. 50,SURSRUFLRQDFRPXQLFDFLyQUHPRWDHQWUHSURJUDPDVHVFULWRVHQHOOHQJXDMHGH SURJUDPDFLyQ-DYD 6LVWHPDV'LVWULEXLGRV 5HPRWH0HWKRG,QYRFDWLRQ $UWXUR'tD]3pUH] Sección de Computación Departamento de Ingeniería Eléctrica CINVESTAV-IPN Av. Instituto Politécnico Nacional No. 2508 Col. San Pedro Zacatenco

Más detalles

Curso de Java EE Todos los Derechos Reservados Global Mentoring 2012 Experiencia y Conocimiento para tu Vida 1

Curso de Java EE Todos los Derechos Reservados Global Mentoring 2012 Experiencia y Conocimiento para tu Vida 1 Todos los Derechos Reservados Global Mentoring 2012 Experiencia y Conocimiento para tu Vida 1 Vivimos en un mundo globalizado, donde la eficiencia y productividad de las empresas es un factor crucial para

Más detalles

CAPITULO 3 ARQUITECTURA DE COMPONENTES GIS EN INTERNET

CAPITULO 3 ARQUITECTURA DE COMPONENTES GIS EN INTERNET CAPITULO 3 ARQUITECTURA DE COMPONENTES GIS EN INTERNET 3.1- ARQUITECTURA DE COMPONENTES GIS La presente tesis trata del diseño y desarrollo de una aplicación basado en el Web para servir datos geográficos

Más detalles

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio y Componentes Web

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio y Componentes Web Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio y titulación de formación continua bonificada expedida por el instituto europeo de estudios empresariales Postgrado en Servicios

Más detalles

Desarrollo de Software con

Desarrollo de Software con Desarrollo de Software con Antonio J. Vélez Q. Universidad del Valle Sede Palmira Contenido Definición de Enterprise Bean Cuando usar Enterprise Beans Tipos de Enterprise Beans Enterprise Bean Con componentes

Más detalles

JAVA RMI (REMOTE METHOD INVOCATION)

JAVA RMI (REMOTE METHOD INVOCATION) JAVA RMI (REMOTE METHOD INVOCATION) RMI RMI (Remote Method Invocation) Mecanismo RPC de Mecanismo mediante el cual los procesos cliente y servidor en una aplicación distribuida se comunican Una aplicación

Más detalles

Postgrado en Java: Especialización en Desarrollo de Componentes de Negocio con Java Beans (Online)

Postgrado en Java: Especialización en Desarrollo de Componentes de Negocio con Java Beans (Online) Postgrado en Java: Especialización en Desarrollo de Componentes de Negocio con Java Beans TITULACIÓN DE FORMACIÓN CONTINUA BONIFICADA EXPEDIDA POR EL INSTITUTO EUROPEO DE ESTUDIOS EMPRESARIALES Postgrado

Más detalles

Presentación del Curso Presencial. Programación Web con Java J2EE

Presentación del Curso Presencial. Programación Web con Java J2EE Presentación del Curso Presencial Programación Web con Java J2EE Tabla de contenido Presentación del curso... 3 Objetivos de aprendizaje... 4 Contenidos del curso... 5 Competencias previas... 6 Recursos...

Más detalles

PROGRAMACION DISTRIBUIDA MobileTracker: Ejemplo de implementación con RMI

PROGRAMACION DISTRIBUIDA MobileTracker: Ejemplo de implementación con RMI PROGRAMACION DISTRIBUIDA MobileTracker: Ejemplo de implementación con RMI Héctor Pérez 2 MobileTracker: Especificación El computador de la torre de control ejecuta el servicio Follower que registra los

Más detalles

Instituto Tecnológico de Costa Rica Sede Regional San Carlos Escuela de Ingeniería en Computación

Instituto Tecnológico de Costa Rica Sede Regional San Carlos Escuela de Ingeniería en Computación Instituto Tecnológico de Costa Rica Sede Regional San Carlos Escuela de Ingeniería en Computación Desarrollo de Funcionalidades para el Sistema de Intermediación de Valores para Fondos de Inversión y Puestos

Más detalles

5.6.8 Estrategias de generación de claves primarias

5.6.8 Estrategias de generación de claves primarias 5.6.8 Estrategias de generación de claves primarias Estrategias de generación de claves primarias (1) En el apartado 2.3.4 se estudiaron varias estrategias de generación de claves primarias Usar el mecanismo

Más detalles

UNIVERSIDAD DE PIURA

UNIVERSIDAD DE PIURA ESPECIALIZACIÓN EN DESARROLLO DE APLICACIONES EMPRESARIALES CON JAVA EE Ofrecer al alumno los conocimientos necesarios para la construcción de sistemas informáticos bajo una arquitectura cliente servidor

Más detalles

Curso JAVA EE 7 2016

Curso JAVA EE 7 2016 Curso JAVA EE 7 2016 Curso de Java EE 7 PC CARRIER 29 de marzo de 2016 Autor: Marc Revenga Esquinas Curso JAVA EE 7 2016 Curso de Java EE 7 Clase 1. Aplicaciones web Java EE. Configuración del servidor

Más detalles

Object Oriented Middleware: Java RMI

Object Oriented Middleware: Java RMI Object Oriented Middleware: Java RMI LSUB GSYC 20 de abril de 2016 (cc) 2015 Laboratorio de Sistemas, Algunos derechos reservados. Este trabajo se entrega bajo la licencia Creative Commons Reconocimiento

Más detalles

Java RMI. las RPC de Java. Parte II. Luis Fernando Llana Díaz. Departamento de Sistemas Informáticos y ProgramaciónUniversidad Complutense de Madrid

Java RMI. las RPC de Java. Parte II. Luis Fernando Llana Díaz. Departamento de Sistemas Informáticos y ProgramaciónUniversidad Complutense de Madrid las RPC de Java. Parte II Departamento de Sistemas Informáticos y Programación Universidad Complutense de Madrid de marzo de 00 Distribución de clases I Es conveniente distinguir: servidor. Necesarias

Más detalles

Programación en Red, Tema 4: RMI. Llamada a procedimientos remotos. Automatización Ventas ebay. Llamada a procedimientos remotos. Server.

Programación en Red, Tema 4: RMI. Llamada a procedimientos remotos. Automatización Ventas ebay. Llamada a procedimientos remotos. Server. Tema 4: Programación en Red, RMI 22 Llamada a procedimientos remotos 24 Automatización Ventas ebay Envio(..), NuevaCompra(..),. Tienda Abierta 24*7 SOAP / RMI Actualiza(..), Comprador GET.. POST.. HTTP

Más detalles

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio

Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio Postgrado en Servicios Java. Experto Desarrollador de Componentes de Negocio y TITULACIÓN DE FORMACIÓN CONTINUA BONIFICADA EXPEDIDA POR EL INSTITUTO EUROPEO DE ESTUDIOS EMPRESARIALES Postgrado en Servicios

Más detalles

La capa de Negocio de la Arquitectura Java EE

La capa de Negocio de la Arquitectura Java EE La capa de Negocio de la Arquitectura Java EE Autores: Dirección: Simon Pickin Florina Almenárez Mendoza Natividad Martínez Madrid Pablo Basanta Val Departamento de Ingeniería Telemática Universidad Carlos

Más detalles

JAVA 1. Introducción

JAVA 1. Introducción Diseño de Interfaces de Usuario JAVA. Introducción. Características Portabilidad Interpretado (bytecodes) Uso de Máquina Virtual Java (JVM) Orientado a Objetos Jerarquía de clases Extensible (packages)

Más detalles