- 浏览: 1333968 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (471)
- 原创文章 (4)
- Database (84)
- J2SE (63)
- Web (26)
- Javascript (30)
- Lucene (11)
- os (13)
- 算法 (8)
- Webservice (1)
- Open projects (18)
- Hibernate (18)
- Spring (15)
- Css (2)
- J2ee (2)
- 综合技术 (18)
- 安全管理 (13)
- PatternsInJava (27)
- NIO (5)
- Ibatis (2)
- 书籍收藏 (1)
- quartz (7)
- 并发编程 (15)
- oracle问题 (2)
- ios (60)
- coco2d-iphone (3)
- C++ (6)
- Zookeeper (2)
- golang (4)
- animation (2)
- android (1)
最新评论
-
dandingge123:
【引用】限制UITextField输入长度的方法 -
qja:
...
对List顺序,逆序,随机排列实例代码 -
安静听歌:
现在在搞这个,,,,,哎~头都大了,,,又freemarker ...
通用大型网站页面静态化解决方案(一) -
springdata-jpa:
java quartz定时任务demo教程源代码下载,地址:h ...
Quartz 配置参考 -
马清天:
[b][/b][list][*]引用[u][/u][/list ...
通用大型网站页面静态化解决方案(一)
Spring HTTP invoker简介
Spring HTTP invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用(意味着可以通过防火墙),并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的对象,这有点类似于webservice,但又不同于webservice,区别如下:
webservice |
HTTP invoker |
跨平台,跨语言 |
只支持java语言 |
支持SOAP,提供wsdl |
不支持 |
结构庞大,依赖特定的webservice实现,如xfire等 |
结构简单,只依赖于spring框架本身 |
项目中使用哪种远程调用机制取决于项目本身的要求。
² HTTP invoker 服务模式
说明:
1. 服务器端:通过HTTP invoker服务将服务接口的某个实现类提供为远程服务
2. 客户端:通过HTTP invoker代理向服务器端发送请求,远程调用服务接口的方法
3. 服务器端与客户端通信的数据需要序列化
配置服务器端和客户端的步骤
配置服务器端
1. 添加springJAR文件
建议使用spring2+.jar版本
2. 创建服务接口
3. 创建服务接口的具体实现类
4. 公开服务
配置客户端
1. 添加springJAR文件
建议使用spring2+.jar版本
2. 创建服务接口
3. 访问服务
实例讲解
服务器端
1.服务接口:UcService.java
它提供两项服务,查询用户信息和记录日志,如下:
- public interface UcService {
- public UserInfo getUserInfobyName(String userName);
- public int recordLog(String username, String point, String operate, String desc);
- }
说明:举这个列子是因为其比较有代表性,它将展示普通数据类型(int,long等)和复杂数据类型(DTO等)的远程调用方式。UserInfo是一个普通的DTO,代码如下:
- public class UserInfo implements Serializable {
- private static final long serialVersionUID = -6970967506712260305L;
- /**用户名*/
- private String userName;
- /**电子邮箱*/
- private String email;
- /**注册日期*/
- private Date registDate;
- public String getUserName() {
- return userName;
- }
- public void setUserName(String userName) {
- this.userName = userName;
- }
- public String getEmail() {
- return email;
- }
- public void setEmail(String email) {
- this.email = email;
- }
- public Date getRegistDate() {
- return registDate;
- }
- public void setRegistDate(Date registDate) {
- this.registDate = registDate;
- }
- }
注意:因为是在网络间传输对象,所以需要将UserInfo实现Serializable接口,并指定一个serialVersionUID(任意值即可,同时客户端也要有这个类,否则在客户端接收对象时会因为serialVersionUID不匹配而出现异常)
回到UcService.java,它提供了两个服务(在这里一个方法代表一个服务功能),我们需要具体的实现类来实现真正的服务
2.实现类是UCServiceImpl.java
- public class UCServiceImpl implements UcService {
- private static Logger pointrecordlog = Logger.getLogger("pointrecordlog");
- private static Logger logger = Logger.getLogger(UCServiceImpl.class);
- private UcFacade ucFacade;
- public void setUcFacade(UcFacade ucFacade) {
- this.ucFacade = ucFacade;
- }
- public UserInfo getUserInfobyName(String userName) {
- UserInfo user = null;
- try {
- user = ucFacade.getUserInfoDetail(userName);
- logger.debug("get userinfo success by username:" + userName);
- } catch (Throwable t) {
- logger.error("get userinfo fail by username:" + userName, t);
- }
- return user;
- }
- public int recordLog(String username, String point, String operate, String desc) {
- int result = 0;
- try {
- pointrecordlog.info(username + " - " + point + " - " + operate + " - " + desc);
- } catch (Throwable t) {
- result = -1;
- logger.error(t);
- }
- return result;
- }
- }
说明:ucFacade是通过spring注入的一个数据查询类,因为它与http invoker没有直接关系,所以不进行介绍。
3.公开服务UcService.java
² WEB-INF/application-context.xml:将接口声明为HTTP invoker服务
- <bean id="httpService"
- class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">
- <property name="service">
- <ref bean="ucService" />
- </property>
- <property name="serviceInterface"
- value="com.netqin.baike.service.UcService">
- </property>
- </bean>
- <bean id="ucService" class="com.netqin.baike.service.impl.UCServiceImpl"/>
说明:HttpInvokerServiceExporter实际上是一个spring mvc控制器,它处理客户端的请求并调用服务实现。
² WEB-INF/service-servlet.xml:HttpInvokerServiceExporter实际上是一个spring mvc控制器,所以需要为其提供spring URL 处理器,这里我们使用SimpleUrlHandlerMapping
- <bean
- class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
- <property name="mappings">
- <props>
- <prop key="/httpService">httpService</prop>
- </props>
- </property>
- </bean>
² WEB-INF/web.xml:配置spring监听及DispatcherServlet
- <context-param>
- <param-name>contextConfigLocation</param-name>
- <param-value>
- /WEB-INF/application-context.xml
- </param-value>
- </context-param>
- <listener>
- <listener-class>
- org.springframework.web.context.ContextLoaderListener
- </listener-class>
- </listener>
- <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>/service/*</url-pattern>
- </servlet-mapping>
说明:不了解为什么这么配置的可以去看看spring mvc方面的资料。
好了,经过以上配置,一个基于spring HTTP invoker的远程服务就完成了,服务的地址为:
http://${serviceName}:${port}/${contextPath}/service/httpService
客户端
1. 创建服务接口及网络间传输的DTO类
为了方便,可以将服务器端创建好的的UcService.java和UserInfo.java拷贝到客户端,或打个jar包放到lib下。
2. 配置访问服务
² WEB-INF/application-context.xml:如果项目中已经存在spring配置文件,则不需要创建该文件,需要配置HTTP invoker的代理
- <bean id="httpService"
- class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
- <property name="serviceUrl">
- <value> http://${serviceName}:${port}/${contextPath}/service/httpService
- </value>
- </property>
- <property name="serviceInterface"
- value="com.netqin.baike.service.UcService">
- </property>
- </bean>
说明:客户端使用HttpInvokerProxyFactoryBean代理客户端向服务器端发送请求,请求接口为UcService的服务
注意:需要修改serviceUrl为实际的服务器地址
² WEB-INF/web.xml:配置spring监听
如果项目没有spring环境,则需要在web.xml中加入对spring的支持
- <context-param>
- <param-name>contextConfigLocation</param-name>
- <param-value>
- /WEB-INF/application-context.xml
- </param-value>
- </context-param>
- <listener>
- <listener-class>
- org.springframework.web.context.ContextLoaderListener
- </listener-class>
- </listener>
3. 访问服务方法
u 读取spring上下文,以远程调用getUserInfobyName方法为例
² 在jsp,servlet,action等等文件中
- UcService service = (UcService) WebApplicationContextUtils
- .getRequiredWebApplicationContext(
- request.getSession().getServletContext()).getBean(
- "httpService");
- UserInfo user = service.getUserInfobyName("hanqunfeng");
² 如果不想配置spring运行环境,可以使用如下方式:
- ApplicationContext applicationContext
- = new FileSystemXmlApplicationContext("classpath:application-context.xml");
- service = (UcService) applicationContext.getBean("httpService");
u 依赖注入,远程调用recordLog方法为例
² 在WEB-INF/application-context.xml中加入如下配置:
- <bean id="abc" class="com.netqin.test.abc">
- <property name="service">
- <ref bean="httpService" />
- </property>
- </bean>
² 为com.netqin.test.abc中加入对service的set方法:
- private UcService service;
- public void setService(UcService service){
- this.service = service;
- }
- public String recordUserLog(String username,String point,String operate,String desc){
- String result = service.recordLog(username, point, operate, desc);
- return result;
- }
评论
发表评论
-
aop:aspect
2011-03-31 11:01 5060package com.albert.spring.proxy ... -
spring包详解
2011-01-27 17:15 1359spring.jar是包含有完整发布的单个jar包,sprin ... -
hibernate部分字段更新的解决方案
2010-12-06 16:33 6752在调用Hibernate的update方法时会更新对象的全部字 ... -
spring 读取applicationContext方式
2010-11-26 14:08 3746加载器目前有两种选择:ContextLoaderListene ... -
spring mvc 流程
2010-11-19 10:00 1754对于流程网上有以下解释: 它的处理流程是这样的: g ... -
Acegi Security -- Spring下最优秀的安全系统
2010-11-11 10:12 1989一 Acegi安全系统介 ... -
spring security 同步session控制
2010-11-05 09:50 3552如果你希望限制单个用户只能登录到你的程序一次,Spring ... -
Spring 国际化的支持:Spring MVC Velocity
2010-10-26 21:19 7552核心提示:在Spring的国际化配置中,一共有三种描述方式 ... -
spring 配置多数据源
2010-10-25 20:52 3157Spring2.0.1以后的版本已经支持配置多数据源,并且可以 ... -
Spring多数据源解决方案
2010-10-25 20:29 6635在很多大型应用中都会对数据进行切分,并且采用多个数据库实例进行 ... -
Spring多数据源解决方案(研究,不确信是正确)
2010-10-25 20:25 2789开发目的:一个协同平台项目,多托管用户,单门户系统,每个托管用 ... -
Hibernate 与 Spring 多数据源的配置
2010-10-24 16:45 1651Spring2.0.1以后的版本已经支持配置多数据源,并且可以 ... -
在spring security3上实现验证码
2010-10-14 12:43 4280关于验证码的实现 验证码的例子现在多如牛毛,大家google ... -
spring javamail
2010-01-07 11:50 3481一直以来都是用javax.mail来写email发送,看了sp ...
相关推荐
Spring HttpInvoker简介** HttpInvoker是Spring Remoting(远程调用)的一种实现方式,它基于HTTP协议,通过序列化和反序列化Java对象来实现远程方法调用。相比于RMI(远程方法调用)和其他远程调用技术,...
公司内部讲义,比较了SOA,RMI和Spring HttpInvoker。并介绍了Spring HttpInvoker的基本使用方法。
Spring HttpInvoker,是一套基于Maven+Spring+SpringMVC+MyBatis框架,还包含了Invoker的客户端及服务器端的demo实例
HttpInvoker是Spring框架的一部分,它允许开发者使用HTTP协议进行远程方法调用,而不需要额外的类库。与Hessian等轻量级通信协议不同,HttpInvoker依赖于Java的序列化机制来处理方法的参数和返回值。 **14.7.1 输出...
org.springframework.remoting.httpinvoker最基本的实现例子,这是3个eclipse的JavaEE工程,全部导入即可,能运行。 初学可以轻松了解Spring HttpInvoker 的结构和使用。
一、Spring HTTP Invoker简介 HTTP Invoker是Spring框架的一个组件,它提供了透明的远程方法调用能力,通过HTTP POST请求将Java对象序列化为字节流,然后在网络中传输,到达目标服务器后反序列化并执行相应的方法。...
在本文中,我们将深入探讨如何使用Spring框架中的HTTP Invoker组件进行远程方法调用(RMI)的实例。HTTP Invoker是Spring框架提供的一种轻量级远程调用解决方案,它利用HTTP协议在客户端和服务端之间传输Java对象。...
HTTP Invoker是Spring框架提供的一个基于HTTP协议的远程调用机制,它通过序列化对象并将其作为HTTP请求的body发送到远程服务器,然后由服务器反序列化并执行相应的方法。这种方式相比于传统的RMI或者Hessian,更加...
Spring HTTP Invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用,也就是说,可以通过防火墙,并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的...
Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和返回值是比较复杂的,通过httpInvoker有巨大的优势。 1. 远程访问流程 1) 服务端定义服务接口 2) 服务端实现服务接口 3) 暴露服务...
NULL 博文链接:https://lggege.iteye.com/blog/369151
3. **配置HTTP Invoker**:在服务端配置Spring,启用HTTP Invoker的支持,将接口绑定到特定的URL路径上,以便客户端可以访问。 4. **客户端构建请求**:在客户端,我们需要创建一个HTTP Invoker的代理对象,该对象...
**Http Invoker:接口测试工具详解** Http Invoker是一款用于接口测试的工具,它允许开发者对Web服务进行调用和测试,验证API的功能和性能。虽然在某些用户看来,Http Invoker可能并不是最易用或者功能最全面的工具...
Java Spring 1.2 远程调用HTTP Invoker是一个基于HTTP协议的远程服务调用框架,它是Spring框架的一部分,允许应用通过HTTP协议进行服务间的通信。这种通信方式相对于RMI(Remote Method Invocation)等其他远程调用...
基于Spring的HttpInvoker实现改写服务器端调用: HttpInvoker.invoker 方法,设置InvokerProcess处理客户端调用: ProxyFactory.proxy 方法,生成接口的代理对象,直接调用方法客户端和服务器端的接口和实体类要...
`Http Invoker`是Spring框架提供的一种基于HTTP协议的RPC实现,主要用于Java应用程序之间进行服务调用。本文将深入探讨如何使用Http Invoker实现RCP客户端与后台的交互,以及相关知识点。 1. **Http Invoker的基本...
HttpInvoker主要面向Spring应用程序,易于集成,但相比Hessian,其数据传输效率较低,因为HTTP协议本身较重,且Java序列化也相对消耗资源。 XFire(后来被Apache CXF吸收)是一款基于XML的Web服务框架,它支持多种...
NULL 博文链接:https://lggege.iteye.com/blog/404124
Http Invoker是Spring框架的一个组件,允许在分布式环境中通过HTTP协议透明地调用Java对象的方法,提供了一种轻量级的RPC(Remote Procedure Call)实现。 **Http Invoker服务端(Service)** 在Http Invoker...
Hessian和Burlap都是基于HTTP的,他们... Spring开发团队意识到RMI服务和基于HTTP的服务之前的空白,Spring的HttpInvoker应运而生。 Spring的HttpInvoker,它基于HTTP之上提供RPC,同时又使用了Java的对象序列化机