Spring与RMI集成

Spring RMI使您可以通过RMI基础结构公开服务。

Spring借助org.springframework.remoting.rmi。 RmiProxyFactoryBean 和org.springframework.remoting.rmi。 RmiServiceExporter 类。

RmiServiceExporter

它为rmi对象提供导出服务。可以通过普通的RMI或RmiProxyFactoryBean访问此服务。

RmiProxyFactoryBean

它是Rmi代理的工厂bean。它公开了可以用作Bean引用的代理服务。

Spring和RMI集成的示例

让我们看看将Spring应用程序与RMI集成的简单步骤:

Calculation.java CalculationImpl.java applicationContext.xml client-beans.xml Host.java Client.java


必需的Jar文件

要运行此示例,您需要加载:

Spring Core jar文件 Spring Remoting jar文件 Spring AOP jar文件

下载spring的所有jar文件,包括core,web,aop,mvc,j2ee,remoting ,oxm,jdbc,orm等。


1、Calculation.java

这是包含一个方法多维数据集的简单接口。

package com.nhooo;
public interface Calculation {
int cube(int number);
}

2、CalculationImpl.java

此类提供了Calculation接口的实现。

package com.nhooo;
public class CalculationImpl implements Calculation{
    @Override
    public int cube(int number) {
        return number*number*number;
    }
}

3、applicationContext.xml

在此xml文件中,我们为CalculationImpl类和 RmiServiceExporter 类定义了bean。我们需要为RmiServiceExporter类的以下属性提供值。

服务 serviceInterface serviceName replaceExistingBinding registryPort

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="calculationBean" class="com.nhooo.CalculationImpl"></bean>
<bean class="org.springframework.remoting.rmi.RmiServiceExporter">
    <property name="service" ref="calculationBean"></property>
    <property name="serviceInterface" value="com.nhooo.Calculation"></property>
    <property name="serviceName" value="CalculationService"></property>
    <property name="replaceExistingBinding" value="true"></property>
    <property name="registryPort" value="1099"></property>
</bean>
</beans>

4、client-beans.xml

在此xml文件中,我们为 RmiProxyFactoryBean 定义了bean。您需要定义此类的两个属性。

serviceUrl serviceInterface

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans.xsd">
    
<bean id="calculationBean" class="org.springframework.remoting.rmi.RmiProxyFactoryBean">
<property name="serviceUrl" value="rmi://localhost:1099/CalculationService"></property>
<property name="serviceInterface" value="com.nhooo.Calculation"></property>
</bean>
</beans>

5、Host.java

它只是获取ApplicationContext的实例。但是您需要先运行此类以运行示例。

package com.nhooo;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Host{
public static void main(String[] args){
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
System.out.println("Waiting for requests");
}
}

6、Client.java

该类获取Calculation的实例并调用该方法。

package com.nhooo;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Client {
public static void main(String[] args)    {
ApplicationContext context = new ClassPathXmlApplicationContext("client-beans.xml");
Calculation calculation = (Calculation)context.getBean("calculationBean");
System.out.println(calculation.cube(7));
}
}