Java2 RMI 入门

2016-02-19 13:02 12 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐Java2 RMI 入门,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - 编程语言 】


  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

来源:http://www.tulaoshi.com/n/20160219/1602804.html

延伸阅读
一、 JDK (Java Development Kit) JDK是整个Java的核心,包括了Java运行环境(Java Runtime Envirnment),一堆Java工具和Java基础的类库(rt.jar)。不论什幺Java应用服务器实质都是内置了某个版本的JDK。因此掌握JDK是学好Java的第一步。最主流的JDK是Sun公司发布的JDK,除了Sun之外,还有很多公司和组织都开...
Below is a simple example of a CORBA program download the source file  b1. prodUCe a idl file like this/b    hello.idl    module HelloApp {    &n...
摘要 通过本章的学习,读者应能知道GUI(图形用户界面)的概念,并且能够使用Java语言来构建一个令人心旷神怡的GUI界面,使你的程序更具有感召力。把握标签、按钮、文本框、选择框、滚动条……等等各种GUI部件的使用方法。 -------------------------------------------------------------------------------- ...
附:Java入门与加深FAQ 一、预备篇 1 什么是Java、Java2、JDK?JDK后面的1.3、1.4.2版本号又是怎么回事? 答:Java是一种通用的,并发的,强类型的,面向对象的编程语言(摘自Java规范第二版) JDK是Sun公司分发的免费Java开发工具,正式名称为J2SDK(Java2 Software Develop Kit)。 2 什么是JRE/J2RE? 答:J2RE是Java2 Runtime En...
标签: Java JAVA基础
Java Learning Path(二)、书籍篇 学习一门新的知识,不可能指望只看一本,或者两本书就能够完全掌握。需要有一个循序渐进的阅读过程。我推荐Oreilly出版的Java系列书籍。 在这里我只想补充一点看法,很多人学习Java是从《Thinking in Java》这本书入手的,但是我认为这本书是不适合初学者的。我认为正确的使用这...

经验教程

207

收藏

13
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部