`

RMI入门(二)实例 --- 亲自将代码调试成功

 
阅读更多


一.创建RMI程序的6个步骤:

1、定义一个远程接口的接口,该接口中的每一个方法必须声明它将产生一个RemoteException异常。

2、定义一个实现该接口的类。

3、使用RMIC程序生成远程实现所需的残根和框架。

4、创建一个服务器,用于发布2中写好的类,在server中注册端口

5. 创建一个客户程序进行RMI调用。

下面是详细的说明


1、定义一个远程接口的接口,该接口中的每一个方法必须声明它将产生一个RemoteException异常。


package com.liuc.server.inter;

import java.rmi.RemoteException;

public interface Hello extends java.rmi.Remote // 需要从Remote继承
{
	public String SayHello() throws RemoteException; // 需要抛出remote异常
}


2、定义一个实现该接口的类。


/*
 * 生成Stub文件  -keepgenerated生成对应的class文件以及源文件
 * cd F:\work\RMITest\WebContent\WEB-INF\classes
 * rmic -keepgenerated  com.liuc.server.inter.impl.HelloImpl
 * 将HelloImpl_Stub考到对应目录下即可
 */
package com.liuc.server.inter.impl;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

import com.liuc.server.inter.Hello;

public class HelloImpl extends UnicastRemoteObject // 必须从UnicastRemoteObject 继承
		implements Hello {
	public HelloImpl() throws RemoteException // 需要一个抛出Remote异常的默认初始化方法
	{
	}

	public String SayHello() // 这个是实现I_Hello接口的方法
	{
		return "Hello world !!";
	}
}

 


3、使用RMIC程序生成远程实现所需的残根Stub 和 框架。

找到对应的class文件的路径参照HelloImpl里面的说明生成残根和框架,将源文件拷贝到HelloImpl相同的目录下

4、创建一个服务器,用于发布2中写好的类。


package com.liuc.server;

import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

import com.liuc.server.inter.Hello;
import com.liuc.server.inter.impl.HelloImpl;

public class RMI_Server {
	public static void main(String[] args) {
		try {
			Registry r = LocateRegistry.getRegistry(9999);
            if(r != null) r = LocateRegistry.createRegistry(9999);
			Hello hello = new HelloImpl(); // 实例化要发布的类
			Naming.rebind("rmi://127.0.0.1:9999/helloServer", hello); // 绑定RMI名称 进行发布
			System.out.println("=== Hello server Ready === ");
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

 

5. 创建一个客户程序进行RMI调用。


package com.liuc.client;

import java.rmi.Naming;

import com.liuc.server.inter.Hello;

public class RMI_Client {
	public static void main(String[] args) {
		try {
			Hello hello = (Hello) Naming.lookup("rmi://127.0.0.1:9999/helloServer"); // 通过RMI名称查找远程对象
			System.out.println(hello.SayHello()); // 调用远程对象的方法
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}

 

6、JRE中配置端口规则

此时如果你运行程序是会报错误的,需要在JRE中配置相应的端口规则

找到JRE的目录,我的目录是D:\Program\JDK1.6\jre\lib\security

打开java.policy文件,在最后添加下面的规则即可

 

grant {

           permission java.net.SocketPermission "*:1024-65535","connect,accept";

  permission java.net.SocketPermission "*:80","connect";

        };


我是把所有可以使用的端口都开了,实际使用时候你可以根据需要只开指定的端口。


附件是工程的源代码文件












 

分享到:
评论

相关推荐

    rmi入门

    【标题】:“RMI入门” 远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一种用于在分布式环境中实现对象间通信的技术。RMI允许一个Java对象调用网络另一端的Java对象的方法,就像调用本地对象...

    J2EE电子商务系统开发从入门到精通--基于Struts和Hibernate技术实现

    ### J2EE电子商务系统开发从入门到精通——基于Struts和Hibernate技术实现 #### J2EE概论 **1.1 简单双层架构到复杂多层架构** - **1.1.1 双层(C/S)软件架构设计** - 双层架构(客户端/服务器架构,Client/...

    JSP快速入门教程

    当用户请求一个JSP页面时,Servlet容器首先将JSP页面转换成一个Servlet类,然后编译这个类,最后执行生成的Servlet实例,将结果返回给客户端。 #### 七、HTML表单元素 在Web开发中,HTML表单是非常重要的组成部分...

    Java Web快速入门——全十讲

    开发工具的选择同样重要,Eclipse、NetBeans、IntelliJ IDEA等都是优秀的Java IDE,它们提供了代码编辑、调试、构建等功能,极大地提高了开发效率。 #### 四、应用部署与配置:Tomcat中的webapps目录 在Tomcat中,...

    dubbo分布式系统入门教学

    《Dubbo分布式系统入门教学》 Dubbo是一个高性能、轻量级的开源Java RPC框架,由阿里巴巴开发并贡献给Apache基金会。它旨在提供一个简单、高效的服务治理解决方案,帮助开发者构建微服务架构。本教学课件将带领你...

    Flex + LCDS + Java 入门教程

    Flex、LCDS(LiveCycle Data Services)和Java是构建富互联网应用程序(Rich Internet Applications, RIA)的...记得下载提供的"Flex + LCDS + Java 入门教程.pdf",里面会有详细步骤和代码示例帮助你逐步学习和实践。

    Rifidi Edge Server v1.2开发者文档

    - `lib`:包含运行Rifidi Edge Server所需的所有代码。 - `docs`:包含所有文档。 - `launchfiles`:包含启动文件,用于配置和运行Rifidi Edge Server。 - **设置开发环境**:首先需要安装必要的开发工具,如...

    dubbo开发者文档

    - **负载均衡**: Dubbo支持多种负载均衡策略,如随机、轮询、最少活跃调用等,确保请求能够合理地分配到各个服务实例。 - **线程模型**: 了解Dubbo的线程模型对于理解其性能影响至关重要。 - **直连提供者、只订阅...

    DWR中文教程 PDF格式

    #### 二、DWR入门 **1.1 简介** DWR是一款强大的工具,用于构建高度交互式的Web应用程序。它通过提供一种简单的方式来实现客户端与服务器之间的通信,从而简化了开发流程。为了有效地使用DWR,开发者应该具备一定...

    EhcacheUserGuide

    #### 二十四、远程网络复制调试(Remote Network Replication Debugging: RMI Replicated Caches) 当使用RMI实现远程网络复制时,可能会遇到各种问题。这部分内容提供了如何调试RMI复制缓存的具体方法。 #### 二十...

    DWR学习笔记(附带很详细的例子)

    DWR的创新之处在于它的"Reverse AJAX"技术,它自动生成基于Java类的JavaScript代码,使得开发者可以在JavaScript中无缝使用Java代码,同时保持Java代码在服务器端运行并能访问服务器资源。为了安全,开发者需要配置...

    dwr的资源包和一写相关网文

    **DWR(Direct Web Remoting)**是一种Java技术,它允许Web应用程序在客户端JavaScript和服务器端Java代码之间进行直接的远程方法调用(RMI)。这个技术极大地简化了富Internet应用程序(RIA)的开发,因为它提供了...

    HelloWorldService:HelloWorldService是MBean服务的简单示例

    为了使`HelloWorldService`实例可用,我们还需要一个JMX连接器,如RMI(远程方法调用)JMX连接器,它允许远程管理工具连接到`MBeanServer`。配置连接器通常涉及修改`jmxremote`相关的系统属性或使用特定的启动参数。...

Global site tag (gtag.js) - Google Analytics