RMI是Java的标准远程调用方法,基于序列化机制实现。将一个组件发布为远程服务,允许客户端远程调用,组件需要满足以下条件:
1、服务接口要继承自java.rmi.Remote接口
2、服务实现类要继承自java.rmi.server.UnicastRemoteObject类
3、服务接口的返回方法全部都是基本类型,或实现了java.io.Serializable接口
对已经编写的组件,要想允许其他Java应用远程调用,就必须对其改造,而Spring允许不对其改造就可以将这些组件发布为远程服务。
在Spring中配置BookeService组件为远程服务:
启动服务端:
客户端调用:
如果客户端也利用了Spring Ioc,可以将RmiProxyFactoryBean在xml文件中装配出来,免去new xxx()操作。
1、服务接口要继承自java.rmi.Remote接口
2、服务实现类要继承自java.rmi.server.UnicastRemoteObject类
3、服务接口的返回方法全部都是基本类型,或实现了java.io.Serializable接口
对已经编写的组件,要想允许其他Java应用远程调用,就必须对其改造,而Spring允许不对其改造就可以将这些组件发布为远程服务。
//POJO
public class Book implements Serializable{
...
}
//服务接口:
public interface BookService{
public Book getBook(int id);
}
//服务实现类
public class BookServiceImpl implements BookService{
public Book getBook(int id){
...
}
}
在Spring中配置BookeService组件为远程服务:
<bean id="bookService" class="test.BookServiceImpl" />
<bean id="rmiService" class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="serviceName" value="BookService"/>
<property name="service" ref="bookService"/>
<property name="serviceInterface" value="test.BookService"/>
<property name="registryPort" value="1099"/>
</bean>
启动服务端:
public void main(String args[]){
new ClassPathXmlApplicationContext("xxx.xml");
}
客户端调用:
public void main(String args[]) throws Exception{
RmiProxyFactoryBean factory=new RmiProxyFactoryBean();
factory.setServiceInterface(UserService.class);
factory.setServiceUrl("rmi://ip:1099/UserService");
factory.afterPropertiesSet();
UserService service=(UserService)factory.getObject();
service.getBook(12);
}
如果客户端也利用了Spring Ioc,可以将RmiProxyFactoryBean在xml文件中装配出来,免去new xxx()操作。
本文介绍如何使用Spring框架简化Java RMI服务的发布与调用过程。通过配置即可将现有组件转变为远程服务,无需修改组件代码。此外,还提供了服务端启动及客户端调用的示例。
882

被折叠的 条评论
为什么被折叠?



