SlideShare una empresa de Scribd logo
1 de 19
Descargar para leer sin conexión
MEMORIA:

UN EJEMPLO SENCILLO
   DE JAVA RMI EN
      WINDOWS
      TECNO ACADEMY
  tecnoacademy.blogspot.com
 Salvador Fernández Fernández
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 es Windows
El jdk utilizado es 1.5.0
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

Para no mezclar el código del cliente, dentro de
rmi4, creo una carpeta a la que llamo cliente.

Utilizaremos dos ventanas de línea de
comandos: una para las acciones sobre el
código de servidor y otra para las operaciones
del cliente.
Clases del servidor
Las ubicamos en la carpeta c:rmi4

Son: EcoRMI.java (interfaz remota),
EcoRMISirviente.java (implementación de
la interfaz remota) y EcoRMIServidor.java
(la aplicación remota)
EcoRMI.java

public interface EcoRMI extends
   java.rmi.Remote
{
  public String eco(String mensaje)
       throws java.rmi.RemoteException;
}
EcoRMISirviente.java (1/2)
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;

public class EcoRMISirviente extends UnicastRemoteObject
       implements EcoRMI
{
public EcoRMISirviente(String nombre) throws RemoteException
  {
    super();
    try
    {
      Naming.rebind(nombre, this);
    } catch (Exception e) {
      System.out.println(quot;Excepcion: quot; + e.getMessage());
      e.printStackTrace();
    }
  }
EcoRMISirviente.java (2/2)
// Implementación del método remoto
 public String eco(String mensaje) throws
    RemoteException
  {
    System.out.println(quot;Recibido: quot; + mensaje);
    return mensaje;
  }
}
import java.rmi.*;

                                             EcoRMIServidor.java
import java.rmi.server.*;

public class EcoRMIServidor
{

    public static void main(String args[])
    {

        // Crea e instala el gestor de seguridad
        System.setSecurityManager(new RMISecurityManager());

        try
        {
          EcoRMISirviente miEco = new
                         EcoRMISirviente(quot;//:4000/mi-EcoRMIquot;);
          System.out.println(quot;Servidor de EcoRMI listo.quot;);
        } catch (Exception e) {
          System.out.println(quot;Excepcion: quot; + e.getMessage());
          e.printStackTrace();
        }
    }
}
java.policy
  En c:rmi4 (servidor) necesitamos un archivo de
  política de seguridad java.policy. Lo más simple
  es habilitar todos los permisos. También lo
  necesita el cliente; no obstante, basta con darle
  la ruta en el momento de ejecutarlo
  posteriormente.

grant {
     permission java.security.AllPermission;
};
Compilar en el servidor

Desde la línea de comandos,
compilamos todas las clases en
c:rmi4 (servidor):

  >cd c:rmi4
  c:rmi4>javac *.java
Generar stub
En la misma línea de comandos, generamos el
archivo de stub:
   c:rmi4>rmic EcoRMISirviente

Se genera un archivo llamado
EcoRMISirviente_stub.class. Es importante,
acordarse de copiarlo en la carpeta cliente.

También debemos copiar en la carpeta cliente
los archivos EcoRMI.java y EcoRMI.class
Clases en el cliente

Además de los archivos
EcoRMISirviente.class, EcoRMI.java y
EcoRMI.class que hemos copiado en
pasos previos, debemos guardar en
c:rmi4cliente el código fuente del cliente
al que denominaremos
EcoRMICliente.java
EcoRMICliente.java (1/2)
import java.io.*;
import java.rmi.*;
import java.rmi.registry.*;
import java.rmi.server.*;

public class EcoRMICliente
{

 public static void main(String args[])

 {
     String mensajeEnviado;
     String mensajeRecibido;
     DataInputStream dataIn = new DataInputStream(System.in);
     BufferedReader in =
             new BufferedReader(new InputStreamReader(dataIn));

     // Crea e instala el gestor de seguridad
     System.setSecurityManager(new RMISecurityManager());

     try {
EcoRMICliente.java (2/2)
EcoRMI miEco = (EcoRMI)Naming.lookup(quot;rmi://quot;
                + args[0] + quot;:4000/quot; + quot;mi-EcoRMIquot;);

          // hace un bucle hasta el fin de la entrada
          System.out.print(quot;Eco> quot;);
          while ((mensajeEnviado = in.readLine()) != null) {
            mensajeRecibido = miEco.eco(mensajeEnviado);
            System.out.println(mensajeRecibido);
            System.out.print(quot;Eco> quot;);
          }
        } catch(Exception e) {
          System.err.println(quot;Excepcion de Sistema: quot; + e);
        }
        System.exit(0);
    }
}
Compilar el cliente

Desde una nueva línea de comandos,
compilamos la clase cliente en
c:rmi4cliente:
 >cd c:rmi4cliente
 c:rmi4cliente>javac EcoRMICliente.java
Lanzar el rmiregistry
Aprovechamos la línea de comandos en la que
compilamos las clases del servidor para lanzar
el registro de RMI en el puerto 4000 (en mi
caso, el puerto por defecto 1099 estaba
ocupado y no lo podía usar). Es importante
advertir que ese es el puerto que he utilizado en
el código de Servidor y del Cliente; si usaseis
otro deberíais cambiar también el código:

   c:rmi4>start rmiregistry 4000

(Debe abrirse una ventana de línea de
comandos vacía y permanecer abierta. Si se
cierra es que algo va mal)
Lanzar el servidor


Desde la misma línea de comandos en la
que estoy ejecuto el servidor:

  c:rmi4>java –Djava.security.policy=file:///c:/rmi4/java.policy EcoRMIServidor
Lanzar el cliente


Desde la misma línea de comandos en la
que compilé la clase del cliente, ejecuto el
proceso cliente:

  c:rmi4cliente>java –Djava.security.policy=file:///c:/rmi4/java.policy
  EcoRMICliente localhost
La ejecución
Una vez lanzados todos los procesos sólo hay
que escribir algo en el prompt de la ventana de
comandos del cliente y observar cómo
efectivamente se produce el eco de lo escrito
en las dos ventanas

                             Cliente
  Servidor

Más contenido relacionado

La actualidad más candente

Certificación CISA
Certificación CISACertificación CISA
Certificación CISAPameluengo
 
Test y pruebas de caja Negra y caja Blanca
Test y pruebas de caja Negra y caja BlancaTest y pruebas de caja Negra y caja Blanca
Test y pruebas de caja Negra y caja BlancaManuel Murcia
 
Modelos de sistemas distribuidos
Modelos de sistemas distribuidosModelos de sistemas distribuidos
Modelos de sistemas distribuidosTensor
 
Mecanismos de exclusion mutua y algoritmos
Mecanismos de exclusion mutua y algoritmosMecanismos de exclusion mutua y algoritmos
Mecanismos de exclusion mutua y algoritmosAbimael hernandez
 
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)Connections Systems
 
Manual configuración GPO
Manual configuración GPOManual configuración GPO
Manual configuración GPOcyberleon95
 
¿Qué es el Modelo Tres Capas?
¿Qué es el Modelo Tres Capas?¿Qué es el Modelo Tres Capas?
¿Qué es el Modelo Tres Capas?Felipe Schmidt
 
Security management.pptx
Security management.pptxSecurity management.pptx
Security management.pptxAhmadUsman79
 
090476 seguridad desistemas -día01 (1) (1)
090476  seguridad desistemas -día01 (1) (1)090476  seguridad desistemas -día01 (1) (1)
090476 seguridad desistemas -día01 (1) (1)Karin Adaly
 

La actualidad más candente (20)

Certificación CISA
Certificación CISACertificación CISA
Certificación CISA
 
Test y pruebas de caja Negra y caja Blanca
Test y pruebas de caja Negra y caja BlancaTest y pruebas de caja Negra y caja Blanca
Test y pruebas de caja Negra y caja Blanca
 
Modelos de sistemas distribuidos
Modelos de sistemas distribuidosModelos de sistemas distribuidos
Modelos de sistemas distribuidos
 
Pentesting
PentestingPentesting
Pentesting
 
Introducción a Java FX
Introducción a Java FXIntroducción a Java FX
Introducción a Java FX
 
Mecanismos de exclusion mutua y algoritmos
Mecanismos de exclusion mutua y algoritmosMecanismos de exclusion mutua y algoritmos
Mecanismos de exclusion mutua y algoritmos
 
Transparencia
TransparenciaTransparencia
Transparencia
 
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
12962797 ccna-3-v-40-exploration-examen-final-modulo-3-50-preguntas (1)
 
Rmi
RmiRmi
Rmi
 
Capa De Sesion
Capa De SesionCapa De Sesion
Capa De Sesion
 
Manual configuración GPO
Manual configuración GPOManual configuración GPO
Manual configuración GPO
 
Cap3 mod3(sol)
Cap3 mod3(sol)Cap3 mod3(sol)
Cap3 mod3(sol)
 
Cap1 mod3(sol)
Cap1 mod3(sol)Cap1 mod3(sol)
Cap1 mod3(sol)
 
Presentación criptografía
Presentación criptografíaPresentación criptografía
Presentación criptografía
 
Interbloqueo
InterbloqueoInterbloqueo
Interbloqueo
 
¿Qué es el Modelo Tres Capas?
¿Qué es el Modelo Tres Capas?¿Qué es el Modelo Tres Capas?
¿Qué es el Modelo Tres Capas?
 
PROCEDIMIENTOS ALMACENADOS
PROCEDIMIENTOS ALMACENADOSPROCEDIMIENTOS ALMACENADOS
PROCEDIMIENTOS ALMACENADOS
 
Security management.pptx
Security management.pptxSecurity management.pptx
Security management.pptx
 
Secure coding practices
Secure coding practicesSecure coding practices
Secure coding practices
 
090476 seguridad desistemas -día01 (1) (1)
090476  seguridad desistemas -día01 (1) (1)090476  seguridad desistemas -día01 (1) (1)
090476 seguridad desistemas -día01 (1) (1)
 

Similar a Ejemplo Java Rmi

P R A C T I C A2
P R A C T I C A2P R A C T I C A2
P R A C T I C A2climancc
 
PowerShell para administradores
PowerShell para administradoresPowerShell para administradores
PowerShell para administradoresPablo Campos
 
Clase 5 controller
Clase 5 controllerClase 5 controller
Clase 5 controllerhydras_cs
 
INSTALACION DE CENTOS Y OPENSSL
INSTALACION DE CENTOS Y OPENSSLINSTALACION DE CENTOS Y OPENSSL
INSTALACION DE CENTOS Y OPENSSLEdson Ortega
 
Symfony2 Formacion y primeros pasos
Symfony2  Formacion y primeros pasosSymfony2  Formacion y primeros pasos
Symfony2 Formacion y primeros pasosSoni BM
 
Maitaining access
Maitaining accessMaitaining access
Maitaining accessTensor
 
Semana 13 ejemplo del uso del rmi
Semana 13   ejemplo del uso del rmiSemana 13   ejemplo del uso del rmi
Semana 13 ejemplo del uso del rmiTerryJoss
 
Php Bitter Sweet Symfony!
Php Bitter Sweet Symfony!Php Bitter Sweet Symfony!
Php Bitter Sweet Symfony!Ricard Luquero
 
MAITAINING ACCESS
MAITAINING ACCESSMAITAINING ACCESS
MAITAINING ACCESSTensor
 
Por qué Symfony2 es tan rápido
Por qué Symfony2 es tan rápidoPor qué Symfony2 es tan rápido
Por qué Symfony2 es tan rápidoCarlos Granados
 
Cómo explotar EternalBlue en Windows Server 2012 R2
Cómo explotar EternalBlue en Windows Server 2012 R2Cómo explotar EternalBlue en Windows Server 2012 R2
Cómo explotar EternalBlue en Windows Server 2012 R2Telefónica
 

Similar a Ejemplo Java Rmi (20)

Java Rmi
Java RmiJava Rmi
Java Rmi
 
Aplicación RMI
Aplicación RMIAplicación RMI
Aplicación RMI
 
Ejemplosencillocon rmi
Ejemplosencillocon rmiEjemplosencillocon rmi
Ejemplosencillocon rmi
 
P R A C T I C A2
P R A C T I C A2P R A C T I C A2
P R A C T I C A2
 
Tema servlets
Tema servletsTema servlets
Tema servlets
 
Tema servlets
Tema servletsTema servlets
Tema servlets
 
Tema servlets
Tema servletsTema servlets
Tema servlets
 
Tema servlets
Tema servletsTema servlets
Tema servlets
 
PowerShell para administradores
PowerShell para administradoresPowerShell para administradores
PowerShell para administradores
 
CRUD básico con Symfony
CRUD básico con SymfonyCRUD básico con Symfony
CRUD básico con Symfony
 
Clase 5 controller
Clase 5 controllerClase 5 controller
Clase 5 controller
 
INSTALACION DE CENTOS Y OPENSSL
INSTALACION DE CENTOS Y OPENSSLINSTALACION DE CENTOS Y OPENSSL
INSTALACION DE CENTOS Y OPENSSL
 
Symfony2 Formacion y primeros pasos
Symfony2  Formacion y primeros pasosSymfony2  Formacion y primeros pasos
Symfony2 Formacion y primeros pasos
 
Maitaining access
Maitaining accessMaitaining access
Maitaining access
 
APIREST LARAVEL Y PHP.pptx
APIREST LARAVEL Y PHP.pptxAPIREST LARAVEL Y PHP.pptx
APIREST LARAVEL Y PHP.pptx
 
Semana 13 ejemplo del uso del rmi
Semana 13   ejemplo del uso del rmiSemana 13   ejemplo del uso del rmi
Semana 13 ejemplo del uso del rmi
 
Php Bitter Sweet Symfony!
Php Bitter Sweet Symfony!Php Bitter Sweet Symfony!
Php Bitter Sweet Symfony!
 
MAITAINING ACCESS
MAITAINING ACCESSMAITAINING ACCESS
MAITAINING ACCESS
 
Por qué Symfony2 es tan rápido
Por qué Symfony2 es tan rápidoPor qué Symfony2 es tan rápido
Por qué Symfony2 es tan rápido
 
Cómo explotar EternalBlue en Windows Server 2012 R2
Cómo explotar EternalBlue en Windows Server 2012 R2Cómo explotar EternalBlue en Windows Server 2012 R2
Cómo explotar EternalBlue en Windows Server 2012 R2
 

Más de Salvador Fernández Fernández

Ejemplo de paso de funciones como parámetros a otra función
Ejemplo de paso de funciones como parámetros a otra funciónEjemplo de paso de funciones como parámetros a otra función
Ejemplo de paso de funciones como parámetros a otra funciónSalvador Fernández Fernández
 
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John DaniSalvador Fernández Fernández
 
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John DaniSalvador Fernández Fernández
 

Más de Salvador Fernández Fernández (20)

Servicio web soap en java con net beans
Servicio web soap en java con net beansServicio web soap en java con net beans
Servicio web soap en java con net beans
 
Web services
Web servicesWeb services
Web services
 
Ejemplo Base de Datos SQLite (Android)
Ejemplo Base de Datos SQLite (Android)Ejemplo Base de Datos SQLite (Android)
Ejemplo Base de Datos SQLite (Android)
 
Práctica nominas
Práctica nominasPráctica nominas
Práctica nominas
 
Ejemplo de paso de funciones como parámetros a otra función
Ejemplo de paso de funciones como parámetros a otra funciónEjemplo de paso de funciones como parámetros a otra función
Ejemplo de paso de funciones como parámetros a otra función
 
Ejemplo usopunteros
Ejemplo usopunterosEjemplo usopunteros
Ejemplo usopunteros
 
Solucion ejercicios punteros cadenas-vectores
Solucion ejercicios punteros cadenas-vectoresSolucion ejercicios punteros cadenas-vectores
Solucion ejercicios punteros cadenas-vectores
 
Ejercicios punteros cadenas-vectores
Ejercicios punteros cadenas-vectoresEjercicios punteros cadenas-vectores
Ejercicios punteros cadenas-vectores
 
Diagramas de flujo
Diagramas de flujoDiagramas de flujo
Diagramas de flujo
 
Introducción a Enterprise Java Beans
Introducción a Enterprise Java BeansIntroducción a Enterprise Java Beans
Introducción a Enterprise Java Beans
 
Colorear fotografias en blanco y negro
Colorear fotografias en blanco y negroColorear fotografias en blanco y negro
Colorear fotografias en blanco y negro
 
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
 
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
10 mentiras con las que siempre engañan a los diseñadores gráficos por John Dani
 
Wallpaper natural
Wallpaper naturalWallpaper natural
Wallpaper natural
 
SQL
SQLSQL
SQL
 
Cableado Estructurado de Red
Cableado Estructurado de RedCableado Estructurado de Red
Cableado Estructurado de Red
 
Redes De Computadores UOC
Redes De Computadores UOCRedes De Computadores UOC
Redes De Computadores UOC
 
Fundamentos Divide Y Venceras
Fundamentos Divide Y VencerasFundamentos Divide Y Venceras
Fundamentos Divide Y Venceras
 
Divide y Vencerás
Divide y VencerásDivide y Vencerás
Divide y Vencerás
 
Java orientado a objetos
Java orientado a objetosJava orientado a objetos
Java orientado a objetos
 

Último

Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21mariacbr99
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...JohnRamos830530
 
investigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIinvestigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIhmpuellon
 
Buenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxBuenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxFederico Castellari
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estossgonzalezp1
 
Guia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosGuia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosJhonJairoRodriguezCe
 
redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativanicho110
 
How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.FlorenciaCattelani
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanamcerpam
 
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxEVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxJorgeParada26
 

Último (10)

Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21Innovaciones tecnologicas en el siglo 21
Innovaciones tecnologicas en el siglo 21
 
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
Resistencia extrema al cobre por un consorcio bacteriano conformado por Sulfo...
 
investigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXIinvestigación de los Avances tecnológicos del siglo XXI
investigación de los Avances tecnológicos del siglo XXI
 
Buenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptxBuenos_Aires_Meetup_Redis_20240430_.pptx
Buenos_Aires_Meetup_Redis_20240430_.pptx
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estos
 
Guia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos BasicosGuia Basica para bachillerato de Circuitos Basicos
Guia Basica para bachillerato de Circuitos Basicos
 
redes informaticas en una oficina administrativa
redes informaticas en una oficina administrativaredes informaticas en una oficina administrativa
redes informaticas en una oficina administrativa
 
How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.How to use Redis with MuleSoft. A quick start presentation.
How to use Redis with MuleSoft. A quick start presentation.
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvana
 
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptxEVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
EVOLUCION DE LA TECNOLOGIA Y SUS ASPECTOSpptx
 

Ejemplo Java Rmi

  • 1. MEMORIA: UN EJEMPLO SENCILLO DE JAVA RMI EN WINDOWS TECNO ACADEMY tecnoacademy.blogspot.com Salvador Fernández Fernández
  • 2. 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 es Windows El jdk utilizado es 1.5.0
  • 3. 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 Para no mezclar el código del cliente, dentro de rmi4, creo una carpeta a la que llamo cliente. Utilizaremos dos ventanas de línea de comandos: una para las acciones sobre el código de servidor y otra para las operaciones del cliente.
  • 4. Clases del servidor Las ubicamos en la carpeta c:rmi4 Son: EcoRMI.java (interfaz remota), EcoRMISirviente.java (implementación de la interfaz remota) y EcoRMIServidor.java (la aplicación remota)
  • 5. EcoRMI.java public interface EcoRMI extends java.rmi.Remote { public String eco(String mensaje) throws java.rmi.RemoteException; }
  • 6. EcoRMISirviente.java (1/2) import java.rmi.*; import java.rmi.server.UnicastRemoteObject; public class EcoRMISirviente extends UnicastRemoteObject implements EcoRMI { public EcoRMISirviente(String nombre) throws RemoteException { super(); try { Naming.rebind(nombre, this); } catch (Exception e) { System.out.println(quot;Excepcion: quot; + e.getMessage()); e.printStackTrace(); } }
  • 7. EcoRMISirviente.java (2/2) // Implementación del método remoto public String eco(String mensaje) throws RemoteException { System.out.println(quot;Recibido: quot; + mensaje); return mensaje; } }
  • 8. import java.rmi.*; EcoRMIServidor.java import java.rmi.server.*; public class EcoRMIServidor { public static void main(String args[]) { // Crea e instala el gestor de seguridad System.setSecurityManager(new RMISecurityManager()); try { EcoRMISirviente miEco = new EcoRMISirviente(quot;//:4000/mi-EcoRMIquot;); System.out.println(quot;Servidor de EcoRMI listo.quot;); } catch (Exception e) { System.out.println(quot;Excepcion: quot; + e.getMessage()); e.printStackTrace(); } } }
  • 9. java.policy En c:rmi4 (servidor) necesitamos un archivo de política de seguridad java.policy. Lo más simple es habilitar todos los permisos. También lo necesita el cliente; no obstante, basta con darle la ruta en el momento de ejecutarlo posteriormente. grant { permission java.security.AllPermission; };
  • 10. Compilar en el servidor Desde la línea de comandos, compilamos todas las clases en c:rmi4 (servidor): >cd c:rmi4 c:rmi4>javac *.java
  • 11. Generar stub En la misma línea de comandos, generamos el archivo de stub: c:rmi4>rmic EcoRMISirviente Se genera un archivo llamado EcoRMISirviente_stub.class. Es importante, acordarse de copiarlo en la carpeta cliente. También debemos copiar en la carpeta cliente los archivos EcoRMI.java y EcoRMI.class
  • 12. Clases en el cliente Además de los archivos EcoRMISirviente.class, EcoRMI.java y EcoRMI.class que hemos copiado en pasos previos, debemos guardar en c:rmi4cliente el código fuente del cliente al que denominaremos EcoRMICliente.java
  • 13. EcoRMICliente.java (1/2) import java.io.*; import java.rmi.*; import java.rmi.registry.*; import java.rmi.server.*; public class EcoRMICliente { public static void main(String args[]) { String mensajeEnviado; String mensajeRecibido; DataInputStream dataIn = new DataInputStream(System.in); BufferedReader in = new BufferedReader(new InputStreamReader(dataIn)); // Crea e instala el gestor de seguridad System.setSecurityManager(new RMISecurityManager()); try {
  • 14. EcoRMICliente.java (2/2) EcoRMI miEco = (EcoRMI)Naming.lookup(quot;rmi://quot; + args[0] + quot;:4000/quot; + quot;mi-EcoRMIquot;); // hace un bucle hasta el fin de la entrada System.out.print(quot;Eco> quot;); while ((mensajeEnviado = in.readLine()) != null) { mensajeRecibido = miEco.eco(mensajeEnviado); System.out.println(mensajeRecibido); System.out.print(quot;Eco> quot;); } } catch(Exception e) { System.err.println(quot;Excepcion de Sistema: quot; + e); } System.exit(0); } }
  • 15. Compilar el cliente Desde una nueva línea de comandos, compilamos la clase cliente en c:rmi4cliente: >cd c:rmi4cliente c:rmi4cliente>javac EcoRMICliente.java
  • 16. Lanzar el rmiregistry Aprovechamos la línea de comandos en la que compilamos las clases del servidor para lanzar el registro de RMI en el puerto 4000 (en mi caso, el puerto por defecto 1099 estaba ocupado y no lo podía usar). Es importante advertir que ese es el puerto que he utilizado en el código de Servidor y del Cliente; si usaseis otro deberíais cambiar también el código: c:rmi4>start rmiregistry 4000 (Debe abrirse una ventana de línea de comandos vacía y permanecer abierta. Si se cierra es que algo va mal)
  • 17. Lanzar el servidor Desde la misma línea de comandos en la que estoy ejecuto el servidor: c:rmi4>java –Djava.security.policy=file:///c:/rmi4/java.policy EcoRMIServidor
  • 18. Lanzar el cliente Desde la misma línea de comandos en la que compilé la clase del cliente, ejecuto el proceso cliente: c:rmi4cliente>java –Djava.security.policy=file:///c:/rmi4/java.policy EcoRMICliente localhost
  • 19. La ejecución Una vez lanzados todos los procesos sólo hay que escribir algo en el prompt de la ventana de comandos del cliente y observar cómo efectivamente se produce el eco de lo escrito en las dos ventanas Cliente Servidor