`
ly_ltw
  • 浏览: 9509 次
文章分类
社区版块
存档分类
最新评论

java rmi

 
阅读更多
RMI网络编程开发之二 如何搭建基于JDK1.5的分布式JAVA RMI 程序

这里讲述的是基于JDK1.5的RMI程序搭建,更简单的说是一个 HelloWorld RMI。

1. 这里是基于JDK1.5的,节省了繁琐的手工编译(生成桩和骨架)。不像1.4之前的RMI。

2. 这里是把客户端和服务器端的两个程序,分布在两个独立的程序里面,而不是同一个package下面。是真正的分布式。

3. 这里不过多阐述原理,这只是一个Hello World!!

好,以下是步骤:

1. 在Eclipse里面创建一个server 端的project。然后,创建一个接口,这个接口是你要向client端开放的方法定义。它叫做:UserManagerInterface,而且必须继承Remote接口。

  1. packagedataserver.rmi.stub;
  2. importjava.rmi.Remote;
  3. importjava.rmi.RemoteException;
  4. importdataserver.rmi.bean.Account;
  5. publicinterfaceUserManagerInterfaceextendsRemote{
  6. publicStringgetUserName()throwsRemoteException;
  7. publicAccountgetAdminAccount()throwsRemoteException;
  8. }

2. 为了证明RMI中,“面向对象”或者是“无缝传递JAVA Object”是何等简单,我们需要定义一个Account类,该类是一个Bean,必须实现implements Serializable序列化接口。这是一个可以在client和server传输的可序列化对象。

  1. packagedataserver.rmi.bean;
  2. importjava.io.Serializable;
  3. publicclassAccountimplementsSerializable,Cloneable{
  4. /**
  5. *
  6. */
  7. privatestaticfinallongserialVersionUID=-1858518369668584532L;
  8. privateStringusername;
  9. privateStringpassword;
  10. publicStringgetUsername(){
  11. returnusername;
  12. }
  13. publicvoidsetUsername(Stringusername){
  14. this.username=username;
  15. }
  16. publicStringgetPassword(){
  17. returnpassword;
  18. }
  19. publicvoidsetPassword(Stringpassword){
  20. this.password=password;
  21. }

  22. }

3. 此时,需要实现你已经开放的接口:

  1. packagedataserver.rmi;
  2. importjava.rmi.RemoteException;
  3. importdataserver.rmi.bean.Account;
  4. importdataserver.rmi.stub.UserManagerInterface;
  5. publicclassUserManagerImplimplementsUserManagerInterface{
  6. publicUserManagerImpl()throwsRemoteException{
  7. //super();
  8. //TODOAuto-generatedconstructorstub
  9. //UnicastRemoteObject.exportObject(this);
  10. }
  11. /**
  12. *
  13. */
  14. privatestaticfinallongserialVersionUID=-3111492742628447261L;
  15. publicStringgetUserName()throwsRemoteException{
  16. //TODOAuto-generatedmethodstub
  17. return"TommyLee";
  18. }
  19. publicAccountgetAdminAccount()throwsRemoteException{
  20. //TODOAuto-generatedmethodstub
  21. Accountaccount=newAccount();
  22. account.setUsername("admin");
  23. account.setPassword("admin");
  24. returnaccount;
  25. }
  26. }

4. 定义一个主程序入口,注册你已经实现的RMI接口,包括开放端口等。其实很简单:

把我们的接口名称,命名为“userManager”,方便client进行调用

  1. packagedataserver.entry;
  2. importjava.rmi.AlreadyBoundException;
  3. importjava.rmi.RemoteException;
  4. importjava.rmi.registry.LocateRegistry;
  5. importjava.rmi.registry.Registry;
  6. importjava.rmi.server.UnicastRemoteObject;
  7. importdataserver.rmi.UserManagerImpl;
  8. importdataserver.rmi.stub.UserManagerInterface;
  9. publicclassEntry{
  10. publicstaticvoidmain(String[]args)throwsAlreadyBoundException,RemoteException{
  11. UserManagerImpluserManager=newUserManagerImpl();
  12. UserManagerInterfaceuserManagerI=(UserManagerInterface)UnicastRemoteObject.exportObject(userManager,0);
  13. //Bindtheremoteobject'sstubintheregistry
  14. Registryregistry=LocateRegistry.createRegistry(2001);
  15. registry.rebind("userManager",userManagerI);
  16. System.out.println("serverisready");
  17. }
  18. }

5. Server端的代码已经全部写完,但是还要把bean类(Account)和接口类(UserMangerInterface)打包成jar,以便可以在下面导入进client端的项目中。

项目--》右键--》导出--》jar--》选择bean和interface--》命名为RmiServerInterface.jar--》finish


6. 开始创建client端的程序。新建一个project。创建完成后,把刚才jar包导入进client的项目中。

7. 导入我们的接口jar以后,可以开始编写一个client端的主程序,并调用server端的方法。

  1. packageweiblog.rmi;
  2. importjava.rmi.NotBoundException;
  3. importjava.rmi.RemoteException;
  4. importjava.rmi.registry.LocateRegistry;
  5. importjava.rmi.registry.Registry;
  6. importdataserver.rmi.stub.UserManagerInterface;
  7. publicclassEntry2{
  8. publicstaticvoidmain(String[]args){
  9. try{
  10. Registryregistry=LocateRegistry.getRegistry("localhost",2001);
  11. UserManagerInterfaceuserManager=(UserManagerInterface)registry.lookup("userManager");
  12. System.out.println(""+userManager.getAdminAccount().getUsername()
  13. +userManager.getAdminAccount().getPassword());
  14. }catch(RemoteExceptione){
  15. //TODOAuto-generatedcatchblock
  16. e.printStackTrace();
  17. }catch(NotBoundExceptione){
  18. //TODOAuto-generatedcatchblock
  19. e.printStackTrace();
  20. }
  21. }
  22. }

8. 启动server端的主程序,然后启动client端的主程序。

server控制台打印:server is ready

client控制台打印:adminadmin


分享到:
评论

相关推荐

    基于JAVA RMI的聊天室

    **基于JAVA RMI的聊天室** Java Remote Method Invocation(RMI)是Java平台提供的一种用于在分布式环境中调用远程对象的方法。在这个“基于JAVA RMI的聊天室”项目中,开发者利用RMI技术构建了一个简单的多用户...

    java RMI技术实现的网络聊天室

    Java RMI(Remote Method Invocation)技术是Java平台中用于分布式计算的一种机制,它允许一个Java对象调用远程计算机上的另一个Java对象的方法。在本案例中,“java RMI技术实现的网络聊天室”是一个使用RMI构建的...

    javaRMI反序列化漏洞验证工具

    Java RMI(Remote Method Invocation,远程方法调用)是一种Java技术,允许在分布式环境中执行远程对象的方法。这个技术的核心是序列化和反序列化过程,它使得对象可以在网络上进行传输。然而,这个特性也可能引入...

    java rmi java rmi

    根据提供的文件信息,我们可以深入探讨Java RMI(Java Remote Method Invocation)的相关知识点,包括其概念、原理、体系结构以及一个具体的示例。 ### RMI的概念 RMI是一种Java技术,它允许开发者创建分布式应用...

    java RMI实现代码

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行远程对象的调用。RMI使得开发者可以像调用本地对象一样调用网络上的对象,极大地简化了...

    JavaRMI快速入门

    Java Remote Method Invocation(Java RMI)是Java编程语言中用于在网络间进行远程对象调用的技术。它是Java平台的标准部分,允许程序员在分布式环境中调用对象的方法,就像它们在同一台计算机上一样。Java RMI对于...

    java rmi 参考文档

    ### Java RMI (Remote Method Invocation) 概念与实践 #### 一、Java RMI简介 Java RMI(Remote Method Invocation)是一种允许调用不同Java虚拟机(JVM)上方法的机制。这些JVM可能位于不同的机器上,也可能在同一...

    java RMI简单Demo

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同网络节点上的Java对象之间进行透明的交互。在Java RMI中,一个对象可以调用另一个位于不同JVM(Java虚拟机)...

    JAVA RMI 传输 SSL加密

    Java RMI (Remote Method Invocation) 是一种用于在Java应用程序之间进行远程通信的技术。为了提高RMI通信的安全性,我们可以使用SSL (Secure Sockets Layer) 或其后继者TLS (Transport Layer Security) 进行加密。...

    Java RMI 简单示例

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同 JVM(Java虚拟机)上的对象的方法。这个简单的示例展示了如何创建一个基本的...

    Java RMI中文规范

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台中用于构建分布式对象系统的关键技术。它允许Java应用程序在不同Java虚拟机(JVM)之间进行远程方法调用,这些虚拟机可能位于同一台计算机或网络上的...

    JavaRMI.pdf

    Java RMI(Remote Method Invocation)是Java编程语言中用于实现远程过程调用的一种技术。它允许运行在客户机上的程序调用位于远程服务器上的对象的方法,从而实现分布式计算。RMI的核心思想是通过接口隐藏底层网络...

    JAVA RMI

    **JAVA RMI(远程方法调用)详解** Java RMI(Remote Method Invocation)是Java平台上的一个核心特性,它允许Java程序在不同的JVM(Java虚拟机)之间进行分布式计算,实现了对象间的远程调用。RMI使得开发者可以像...

    通过Java RMI实现远程调用的一个简单例子

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同JVM上的对象的方法。这个简单的例子将引导我们了解如何利用Java RMI实现远程...

    java rmi HelloWorld版(源码)

    Java RMI,全称为Remote Method Invocation,是Java平台上的一个标准API,用于实现分布式计算,使得在不同Java虚拟机(JVM)上的对象能够互相调用方法。这个"java rmi HelloWorld版(源码)"的压缩包文件提供了一个...

    JAVA RMI测试代码

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许Java对象在不同的网络环境中进行交互,就像调用本地方法一样。RMI是构建分布式应用的重要工具,尤其适用于需要跨...

    Java RMI 可运行实例

    Java Remote Method Invocation (RMI) 是Java平台提供的一种强大的分布式计算技术,允许在不同网络环境中的Java对象之间进行远程方法调用。这个可运行实例是一个实际应用RMI概念的示例,它展示了如何构建和运行一个...

    javaRMI完整版.pdf

    Java RMI 完整版 Java Remote Method Invocation(RMI)是一种分布式对象技术,允许使用 Java 编写分布式对象,不同的 Java 虚拟机(JVM)之间进行对象间的通讯。这使得应用程序(Application)可以远程调用方法,...

    JAVA RMI简单例子

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行方法调用,仿佛这些方法都在本地对象上执行一样。这个"JAVA RMI简单例子"旨在帮助我们...

Global site tag (gtag.js) - Google Analytics