Spring RMI使您可以通過(guò)RMI基礎(chǔ)結(jié)構(gòu)公開服務(wù)。
Spring借助org.springframework.remoting.rmi。 RmiProxyFactoryBean 和org.springframework.remoting.rmi。 RmiServiceExporter 類。
RmiServiceExporter
它為rmi對(duì)象提供導(dǎo)出服務(wù)。可以通過(guò)普通的RMI或RmiProxyFactoryBean訪問(wèn)此服務(wù)。
RmiProxyFactoryBean
它是Rmi代理的工廠bean。它公開了可以用作Bean引用的代理服務(wù)。
讓我們看看將Spring應(yīng)用程序與RMI集成的簡(jiǎn)單步驟:
Calculation.java CalculationImpl.java applicationContext.xml client-beans.xml Host.java Client.java
要運(yùn)行此示例,您需要加載:
Spring Core jar文件 Spring Remoting jar文件 Spring AOP jar文件
下載spring的所有jar文件,包括core,web,aop,mvc,j2ee,remoting ,oxm,jdbc,orm等。
1、Calculation.java
這是包含一個(gè)方法多維數(shù)據(jù)集的簡(jiǎn)單接口。
package com.nhooo; public interface Calculation { int cube(int number); }
2、CalculationImpl.java
此類提供了Calculation接口的實(shí)現(xiàn)。
package com.nhooo; public class CalculationImpl implements Calculation{ @Override public int cube(int number) { return number*number*number; } }
3、applicationContext.xml
在此xml文件中,我們?yōu)镃alculationImpl類和 RmiServiceExporter 類定義了bean。我們需要為RmiServiceExporter類的以下屬性提供值。
服務(wù) 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文件中,我們?yōu)?strong> RmiProxyFactoryBean 定義了bean。您需要定義此類的兩個(gè)屬性。
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的實(shí)例。但是您需要先運(yùn)行此類以運(yùn)行示例。
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的實(shí)例并調(diào)用該方法。
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)); } }