概念
Spring HTTP
invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用(意味着可以通过防火墙),并使用java的序列化机制在网络间传递对象。
效率
远程调用效率: rmi>spring
http invoker>webservice
优点
1.spring http invoker
采用java的序列化机制,并采用类似rmi的方式调用,既能够使用http协议轻松穿过防火墙,又能够保证高效的远程调用。
2.轻量级的远程调用模型,对于采用spring的项目可以无缝嵌入,侵入性小。
3.非常简单,容易上手。
缺点
只支持spring.
例子
服务端
1.web.xml
-
<servlet>
-
<servlet-name>service</servlet-name>
-
<servlet-class>
-
org.springframework.web.servlet.DispatcherServlet
-
</servlet-class>
-
<load-on-startup>1</load-on-startup>
-
</servlet>
-
<servlet-mapping>
-
<servlet-name>service</servlet-name>
-
<url-pattern>/httpservice/*</url-pattern>
- </servlet-mapping>
2. spring配置文件
-
<beans>
-
<bean id="userInfoServiceProxy" class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
-
<property name="service" ref="userInfoService"/>
-
<property name="serviceInterface" value="cn.gov.zjport.skeleton.sso.UserInfoService"/>
-
</bean>
- </beans>
其中userInfoService为项目原有的service
3.
增加一个service-servlet.xml,放在web-inf目录下
-
<?xml version="1.0" encoding="UTF-8"?>
-
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
-
-
<beans>
-
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
-
<property name="mappings">
-
<props>
-
<prop key="/userInfoService">userInfoServiceProxy</prop>
-
</props>
-
</property>
-
</bean>
- </beans>
至此服务端发布完毕。
客户端
1.
spring配置文件
-
<bean id="userInfoService" class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
-
<property name="serviceUrl" value="http://<server>:<port>/<domain>/httpservice/userInfoService"/>
-
<property name="serviceInterface" value="cn.gov.zjport.skeleton.sso.UserInfoService"/>
- </bean>
2. 调用代码
- String xml=userInfoService.getUserInfo("simpleadmin", true);
与非远程调用代码一摸一样。
所以说对于采用spring的项目,只需要简单配置,即可实现分布式部署与远程调用。
相关推荐
Spring HttpInvoker,是一套基于Maven+Spring+SpringMVC+MyBatis框架,还包含了Invoker的客户端及服务器端的demo实例
公司内部讲义,比较了SOA,RMI和Spring HttpInvoker。并介绍了Spring HttpInvoker的基本使用方法。
org.springframework.remoting.httpinvoker最基本的实现例子,这是3个eclipse的JavaEE工程,全部导入即可,能运行。 初学可以轻松了解Spring HttpInvoker 的结构和使用。
NULL 博文链接:https://tou3921.iteye.com/blog/1729111
Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和返回值是比较复杂的,通过httpInvoker有巨大的优势。 1. 远程访问流程 1) 服务端定义服务接口 2) 服务端实现服务接口 3) 暴露服务...
spring+httpInvoker 实例,含服务端和客户端代码,myEclipse工程,直接导入就可以测试,适合初学者. 提供 普通参数返回值和自定义对象返回值,两个方式.
NULL 博文链接:https://lggege.iteye.com/blog/369151
Spring HTTP Invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用,也就是说,可以通过防火墙,并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的...
springboot-httpinvoker-demo.zip
和Hessian的轻量级传输协议不同的是,Spring HttpInvoker使用Java序列化来序列化参数和返回值,然后基于HTTP协议传输经序列化后的对象。当参数或返回值是复杂类型,并且不能通过Hessian的序列化机制序列化时,...
基于Spring的HttpInvoker实现改写服务器端调用: HttpInvoker.invoker 方法,设置InvokerProcess处理客户端调用: ProxyFactory.proxy 方法,生成接口的代理对象,直接调用方法客户端和服务器端的接口和实体类要...
NULL 博文链接:https://lggege.iteye.com/blog/404124
但当传递过来的RPC消息中包含序列化... Spring开发团队意识到RMI服务和基于HTTP的服务之前的空白,Spring的HttpInvoker应运而生。 Spring的HttpInvoker,它基于HTTP之上提供RPC,同时又使用了Java的对象序列化机
接口测试工具,不太好用,不建议使用,自己传着玩儿的
NULL 博文链接:https://lee79.iteye.com/blog/926647
NULL 博文链接:https://lee79.iteye.com/blog/943207
org.springframework.remoting.httpinvoker.AbstractHttpInvokerRequestExecutor.class org.springframework.remoting.httpinvoker.CommonsHttpInvokerRequestExecutor.class org.springframework.remoting....
项目工程结构如下图所示,除了包含spring定义远程服务org.springframework.remoting.httpinvoker.*部分节点代码(红框框部分,具体设计代码部分参考相关代码示例说明文章),还包含springmvc等其他示例部分可以忽略...
它是 Spring HttpInvoker的一个轻量级选择,特别适合于当你不想在客户端程序中使用Spring框架。 API访问授权的开放标准 OAuth OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式...