使用Spring框架实现远程服务暴露与调用

一、前言

Spring框架提供了通过HTTP协议实现远程调用的方式,具体是调用方使用HttpInvokerProxyFactoryBean生成一个代理对象,通过代理对象远程通过http服务调用服务提供方法的服务并,服务提供方通过HttpInvokerServiceExporter在服务端暴漏远程调用接口。

二、远程服务暴露

2.1 简单使用

  • 第一步需要定义需要暴露的服务接口和实现
public interface UserServiceBo {
    String sayHello(String name);  
    String sayHello2(String name);  
    String testPojo(Person person);
}
public class UserServiceImpl implements UserServiceBo{

    @Override
    public String sayHello(String name) {
    
        return name; 
    }

    @Override
    public String sayHello2(String name) {
    
        return name;
    }

    @Override
    public String testPojo(Person person) {
        return JSON.toJSONString(person);
    }  
}
  • 第二步创建服务导出HttpInvokerServiceExporter的实例
    <bean id="userService" class="com.test.UserServiceImpl" />
<bean name="useServiceExporter" class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
    <property name="service" ref="userService" />
    <property name="serviceInterface" value="com.test.UserServiceBo" />
</bean>
  • 第三步 暴露远程服务的URL
<bean id="simpleUrlRequestHandler"
        class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <property name="alwaysUseFullPath" value="true" />
    <property name="urlMap">
        <map>
          <entry key="/remote/test/userService" value-ref="useServiceExporter" />
        </map>
    </property>
</bean>

注意这个bean要配置到dispatcher类的配置文件里面。

2.2 原理

image.png

三、远程服务调用

3.1 简单使用

    HttpInvokerProxyFactoryBean factoryBean = new HttpInvokerProxyFactoryBean();
        factoryBean.setServiceUrl("http://127.0.0.1:7001/test/userService.do");
        factoryBean.setServiceInterface(UserServiceBo.class);
        factoryBean.afterPropertiesSet();
        UserServiceBo userService = (UserServiceBo) factoryBean.getObject();
        
        System.out.println(userService.sayHello("jiaduo"));
        

3.2 原理

image.png

四、总结

Spring框架提供了通过HTTP协议实现远程调用的方式,我们可以通过重写invoker自定义http请求header和body传递一些信息到服务暴露端,比如函数签名指,序列化协议等。

通过重写exporter可以进行鉴权操作,比如进行函数签名校验,然后可以定制反序列化方式。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,829评论 19 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,118评论 6 342
  • 成年之后再去看安徒生童话,带来了更多的深思,从中能看到更多的内涵。红舞鞋并不是简单的告诫孩子不要有虚荣心。 可能是...
    sherlywu88阅读 13,573评论 0 0
  • 我有个姓李的爷爷去世了,在家已经停放了三天,今天要出山了。 还没睡醒,就听到妈妈在叫我,说什么八点半就要去那里吃饭...
    大啊大的阅读 10,780评论 0 0

友情链接更多精彩内容