广

Java编程

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

    Java2 RMI 入门

    2018-10-13 10:38:21 次阅读 稿源:互联网
    零七广告

      RMI从Java1.1开始,RMI使得运行于不同JVM(包括不同主机)上的Java应用程序可以彼此通话。
      即:一个JVM中的Java应用程序可以调用另一JVM上的对象(远程对象)所定义的方法。
      Java RMI有着重要的意义。RMI在Java网络编程和高级编程中都有重要的应用,如EJB, Jini等。
      Java2对RMI做了很多增强和改进,如安全性,动态代码下载等。
      本文给出了一个最简单的例子,以说明其中的一些基本原理。本文的特点是注重了实际开发和真正的运行
      环境相结合,模拟了RMI真正的开发和运行过程。
      
      1. 实现远程接口,生成远程对象,存根(Stub)和框架(Skeleton)
      
      实现远程接口,远程接口告诉JVM:实现了该接口的对象可以远程调用及有哪些方法可以调用。
      本例子中定义了sayHello()。由于远程调用会涉及到网络通讯,因此这些方法都要抛出RemoteException.
      远程接口和远程对象可以由A开发,并把远程接口(Hello)d打包分给Client端开发者B。
      
      建立f:server目录,把Hello.java和HelloImpl.java拷贝到该目录中。
      
      // Hello.java
      package jdeveloper.rmi;
      
      import java.rmi.Remote;
      import java.rmi.RemoteException;
      
      public interface Hello extends Remote {
      String sayHello() throws RemoteException;
      }
      
      生成远程对象.
      // HelloImpl.java
      package jdeveloper.rmi;
      
      import java.rmi.Naming;
      import java.rmi.RemoteException;
      import java.rmi.RMISecurityManager;
      import java.rmi.server.UnicastRemoteObject;
      
      public class HelloImpl extends UnicastRemoteObject
      implements Hello {
      
      public HelloImpl() throws RemoteException {
      super();
      }
      
      public String sayHello() {
      return "Hello World!";
      }
      
      public static void main(String args[]) {
      
      // Create and install a security manager
      if (System.getSecurityManager() == null) {
      System.setSecurityManager(new RMISecurityManager());
      }
      try {
      Hello obj = new HelloImpl();
      // Bind this object instance to the name "HelloServer"
      Naming.rebind("HelloServer", obj);
      System.out.println("HelloServer bound in registry");
      } catch (Exception e) {
      System.out.println("HelloImpl err: " + e.getMessage());
      e.printStackTrace();
      }
      }
      }
      存根(Stub)和框架(Skeleton)
      f:
      cd server
      javac -d . Hello.java
      javac -d . HelloImpl.java
      rmic -d . jdeveloper.rmi.HelloImpl
      
      jar cvf hello.jar jdevelopermiHello.class 把hello.jar分发给Client端的开发者B。
      
      存根(Stub)的存放!
      存根(Stub)是动态下载的。Client通过存根(Stub)和远程对象的框架(Skeleton)通讯,对Client来
      讲就象操作本地对象一样。在大多数情况下,可下载的代码放到http服务器的某个目录中。本例子放到http://hjc/rmi下。
      hjc:机器名,rmi:http的一个目录。假如只是单机测试则可以放到某个目录下 如f:serverclasses.
      本文将对以上两种方法都给出运行的步骤(policy文件和bat文件)。
      
      2. 实现Client端程序
      // HelloClient.java
     

    零七网部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与零七网进行文章共享合作。

    零七广告
    零七广告
    零七广告
    零七广告