一.创建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";
};
我是把所有可以使用的端口都开了,实际使用时候你可以根据需要只开指定的端口。
附件是工程的源代码文件