完整的程序代码:
Remote interface
import java.rmi.*;
public interface MyRemote extends Remote{ //定义接口,必须继承java.rmi.Remote
public string sayHello() throws RemoteException; //所有接口方法必须声明RemoteException,返回值类型必须是Primitive,string,集合等主要类型或Serializable的。
}
Remote service(实现)
// 你的服务必须要实现Remote,就是客户端会调用的方法
import java.rmi.*;
import java.rmi.server.*;
public class MyRemoteImpl extends UnicastRemoteObject implements MyRemote {
//要成为远程服务对象,对象必须要有与远程有关的功能。最简单的方式是继承UnicastRemoteObject(来自java.rmi.server),以让这个父类处理这些工作
public String SayHello(){ //必须实现所有接口中的方法
return "Server says, 'Hey'";
}
public MyRemoteImpl() throws RemoteException{}
//UnicastRemoteObject的构造函数会抛出RemoteException,所以我们需要声明父类的构造函数会抛出异常。因为类初始化的时候会先调用父类的构造函数,因此子类的构造函数必须声明会抛出异常,但是这里我们没有子类的实例变量需要初始化,因此可以什么都不用写
public static void main(String[] args){
try {
MyRemote service = new MyRemoteImpl(); //创建名为service的服务对象
Naming.rebind("Remote Hello", service); //帮服务命名(客户端会靠名字查询registry),并向RMI registry注册,RMI会把stub做交换并将stub加入registry
}
catch(Exception ex) {
ex.printStackTrace();
}
}
}
启动远程服务
在命令行执行以下命令
% rmic MyRemoteImpl //对实现出的类执行rmic,产生stub和skeleton
% rmiregistry //启动rmiregistry,要确保是从该类的目录启动
% java MyRemoteImpl //启动服务
客户端程序代码
import java.rmi.*;
public class MyRemoteClient{
public static void main(String[] args){
new MyRemoteClient().go()
}
public void go(){
try{
MyRemote service = (MyRemote) Naming.lookup("rmi://127.0.0.1/Remote Hello");
//从registry中取得stub对象
String s = service.sayHello();
System.out.println(s);
}
catch(Exception ex){
ex.printStackTrace();
}
}
}