在spring中,使用RMI技术

RMI服务端应用程序:

   1.自定义远程接口

        代码如下:

package com.ghj.packageofrmi;
/**
 * 定义远程接口。*/
public interface IHelloWordService{
   /**
     * 获取信息*/
    String getMsg();
}

 该自定义远程接口声明每个要远程调用的抽象方法。
        该接口特点:
        a、该接口没有继承java.rmi.Remote接口;
        b、该接口中的每个抽象方法没有抛出RemoteException异常或RemoteException 的父类异常;

  2.自定义远程接口实现类

      代码如下:

package com.ghj.packageofrmi;
/**
 * 远程接口实现类。
 */
public class HelloWordService implements IHelloWordService{
    /**
     * 获取信息
     */
    public String getMsg(){
        return "Hello World!"; 
    }
}

        该实现类特点:
        a、该实现类必须实现自定义远程接口内的每个远程抽象方法;
        b、该实现类没有继承java.rmi.UnicastRemoteObject类;
        c、该实现类中默认的构造方法没有显示地写出来,该默认构造方法更没有声明抛出RemoteException异常;
        d、该实现类也可以含有其它非远程接口定义的抽象方法或非接口方法(即实现类内部自定义的方法,这些方法不能使用@Override进行注释),但客户端不能调用这些新增的方法(别忘了,这些方法并不是自定义远程接口内的抽象方法)。
        一句话,该实现类是普通Java实现类没有区别。

   3,在xml文件中配置RMI服务端

        代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans 
    xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-2.5.xsd">
     <!-- RMI服务端 -->
    <!-- RMI服务端远程接口实现类 --> 
    <bean id="helloWordService" class="com.ghj.packageofrmi.HelloWordService" scope="prototype"/>
      <bean class="org.springframework.remoting.rmi.RmiServiceExporter">
        <!-- 将远程接口实现类对象设置到RMI服务中 -->
        <property name="service" ref="helloWordService" />
        <!-- 设置RMI服务名,为RMI客户端依据此服务名获取远程接口实现类对象引用奠定基础 -->
        <property name="serviceName" value="helloWord" />
        <!-- 将远程接口设置为RMI服务接口 -->
        <property name="serviceInterface" value="com.ghj.packageofrmi.IHelloWordService" />
        <!-- 为RMI服务端远程对象注册表设置端口号-->
        <property name="registryPort" value="9090" />
        <!-- 其他属性可以查看org.springframework.remoting.rmi.RmiServiceExporter的类及其子类获取到-->
    </bean>
</beans> 

        该xml文件的配置就相当于服务端RMI启动类内被try-catch包裹的那段Java代码。

    4.启动RMI服务端

        代码如下:

package com.ghj.packageoftest;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
 * 启动RMI服务端
 */
public class StartRMIServer {
    public static void main(String[] args) {
        new ClassPathXmlApplicationContext("conf/spring/applicationContext.xml");
        System.out.println("RMI服务端启动!!!");
    }
}

   将RMI服务端配置到Spring框架内后,启动它是很简单的——只需Java加载配置文件上下文,在Spring容器生成相应的bean即可。

 RMI客户端应用程序:

    1.自定义包含了RMI服务端自定义远程接口内某些抽象方法的RMI客户端接口

        代码如下:

package com.ghj.packageofrmi;
/**
 * 自定义包含了RMI服务端自定义远程接口内某些抽象方法的RMI客户端接口
 */
public interface IHelloWord{
    /**
     * 获取信息
     */
    String getMsg();
}

       该接口特点:
       a.该接口的接口名无需和RMI服务端自定义远程接口名称相同;
       b.该接口无须继承java.rmi.Remote接口;
       c.该接口中需要通过RMI服务端远程对象调用的接口抽象方法需要和RMI服务端一样(这里的“一样”是指接口名、方法名和参数列表一样,注意:这里没有提及方法返回值类型,实验证明,返回值类型可以相同也可以是RMI服务端自定义远程接口相应抽象方法返回值类型的父类,例如该接口中的返回值类型完全可以改为Object);
       d.该接口中的抽象方法无须抛出RemoteException异常;
       e.该接口可以包含RMI服务端自定义远程接口内不存在的抽象方法;
       f.该接口无须包含RMI服务端自定义远程接口的所有抽象方法;
       g.该接口完全可以直接复制RMI服务端自定义远程接口,但从代码精简的角度讲还是只保留需要的抽象接口为好。

   2.在xml文件中配置RMI服务端

        代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans 
    xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-2.5.xsd">
    <!--RMI客户端-->
    <bean id="rmiProxyFactory" class="org.springframework.remoting.rmi.RmiProxyFactoryBean"> 
        <property name="serviceUrl" value="rmi://localhost:9090/helloWord"/>
        <property name="serviceInterface" value="com.ghj.packageofrmi.IHelloWord"/>
        <!-- 当连接失败时是否刷新远程调用stub -->
        <property name="refreshStubOnConnectFailure" value="true"/>
    </bean>
</beans>

  该xml文件的配置就相当于客户端RMI调用远程方法测试类内被try-catch包裹的那段Java代码。

   3.启动RMI客户端

        代码如下:

package com.ghj.packageoftest;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.ghj.packageofrmi.IHelloWord;
/**
 * 启动RMI客户端
 */
public class RMIClient {
    public static void main(String[] args){
        ApplicationContext ctx = new ClassPathXmlApplicationContext("conf/spring/applicationContext.xml");
        IHelloWord helloWord = (IHelloWord) ctx.getBean("rmiProxyFactory");
        System.out.println(helloWord.getMsg());
    }
}

   从该Java类中可以看出来远程对象地址是通过RMI代理工厂的实例获取的。

  转载:https://blog.csdn.net/gaohuanjie/article/details/43083191

posted @ 2018-09-17 21:38  小码农成长记  阅读(382)  评论(0编辑  收藏  举报