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)