`

Spring HTTP invoker简介

阅读更多
核心提示:Spring HTTP invoker简介 Spring HTTP invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用(意味着可以通过防火墙),并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的对象,这有点类似于we

Spring HTTP invoker简介
Spring HTTP invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用(意味着可以通过防火墙),并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的对象,这有点类似于webservice,但又不同于webservice,区别如下:

 

webservice

HTTP invoker

跨平台,跨语言

只支持java语言

支持SOAP,提供wsdl

不支持

结构庞大,依赖特定的webservice实现,如xfire

结构简单,只依赖于spring框架本身

 
项目中使用哪种远程调用机制取决于项目本身的要求。

 

²        HTTP invoker 服务模式

 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

它提供两项服务,查询用户信息和记录日志,如下:

  1. public interface UcService {   
  2.   
  3.            public UserInfo getUserInfobyName(String userName);   
  4.   
  5.            public int recordLog(String username, String point, String operate, String desc);   
  6.   
  7. }   

说明:举这个列子是因为其比较有代表性,它将展示普通数据类型(int,long等)和复杂数据类型(DTO等)的远程调用方式。UserInfo是一个普通的DTO,代码如下:

  1. public class UserInfo implements Serializable {   
  2.   
  3.     private static final long serialVersionUID = -6970967506712260305L;   
  4.   
  5.     /**用户名*/  
  6.   
  7.     private String userName;   
  8.   
  9.     /**电子邮箱*/  
  10.   
  11.     private String email;   
  12.   
  13.     /**注册日期*/  
  14.   
  15.     private Date registDate;   
  16.   
  17.     
  18.   
  19.     public String getUserName() {   
  20.   
  21.         return userName;   
  22.   
  23.     }   
  24.   
  25.     public void setUserName(String userName) {   
  26.   
  27.         this.userName = userName;   
  28.   
  29.     }   
  30.   
  31.     public String getEmail() {   
  32.   
  33.         return email;   
  34.   
  35.     }   
  36.   
  37.     public void setEmail(String email) {   
  38.   
  39.         this.email = email;   
  40.   
  41.     }   
  42.   
  43.      public Date getRegistDate() {   
  44.   
  45.         return registDate;   
  46.   
  47.     }   
  48.   
  49.     public void setRegistDate(Date registDate) {   
  50.   
  51.         this.registDate = registDate;   
  52.   
  53.     }   
  54.   
  55. }   
  56.   

注意:因为是在网络间传输对象,所以需要将UserInfo实现Serializable接口,并指定一个serialVersionUID(任意值即可,同时客户端也要有这个类,否则在客户端接收对象时会因为serialVersionUID不匹配而出现异常)

 回到UcService.java,它提供了两个服务(在这里一个方法代表一个服务功能),我们需要具体的实现类来实现真正的服务

 

2.实现类是UCServiceImpl.java

  1. public class UCServiceImpl implements UcService {   
  2.   
  3.     private static Logger pointrecordlog = Logger.getLogger("pointrecordlog");   
  4.   
  5.     private static Logger logger = Logger.getLogger(UCServiceImpl.class);   
  6.   
  7.     private UcFacade ucFacade;   
  8.   
  9.     public void setUcFacade(UcFacade ucFacade) {   
  10.   
  11.         this.ucFacade = ucFacade;   
  12.   
  13.     }   
  14.   
  15.     public UserInfo getUserInfobyName(String userName) {   
  16.   
  17.         UserInfo user = null;   
  18.   
  19.         try {   
  20.   
  21.             user = ucFacade.getUserInfoDetail(userName);   
  22.   
  23.             logger.debug("get userinfo success by  username:" + userName);   
  24.   
  25.         } catch (Throwable t) {   
  26.   
  27.             logger.error("get userinfo fail by  username:" + userName, t);   
  28.   
  29.         }   
  30.   
  31.         return user;   
  32.   
  33.     }   
  34.   
  35.     public int recordLog(String username, String point, String operate, String desc) {   
  36.   
  37.         int result = 0;   
  38.   
  39.         try {   
  40.   
  41.             pointrecordlog.info(username + " - " + point + " - " + operate + " - " + desc);   
  42.   
  43.         } catch (Throwable t) {   
  44.   
  45.             result = -1;   
  46.   
  47.             logger.error(t);   
  48.   
  49.         }   
  50.   
  51.         return result;   
  52.   
  53.     }   
  54.   
  55. }   
  56.   

说明:ucFacade是通过spring注入的一个数据查询类,因为它与http invoker没有直接关系,所以不进行介绍。

3.公开服务UcService.java

²        WEB-INF/application-context.xml:将接口声明为HTTP invoker服务

  1. <bean id="httpService"  
  2.   
  3.         class="org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter">  
  4.   
  5.         <property name="service">  
  6.   
  7.             <ref bean="ucService" />  
  8.   
  9.         </property>  
  10.   
  11.         <property name="serviceInterface"  
  12.   
  13.             value="com.netqin.baike.service.UcService">  
  14.   
  15.         </property>  
  16.   
  17.     </bean>  
  18.   
  19.     <bean id="ucService" class="com.netqin.baike.service.impl.UCServiceImpl"/>  
  20.   

说明:HttpInvokerServiceExporter实际上是一个spring mvc控制器,它处理客户端的请求并调用服务实现。

²         WEB-INF/service-servlet.xml:HttpInvokerServiceExporter实际上是一个spring mvc控制器,所以需要为其提供spring URL 处理器,这里我们使用SimpleUrlHandlerMapping

  1. <bean  
  2.   
  3.         class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">  
  4.   
  5.          <property name="mappings">  
  6.   
  7.             <props>  
  8.   
  9.                   <prop key="/httpService">httpService</prop>  
  10.   
  11.             </props>  
  12.   
  13.         </property>  
  14.   
  15.     </bean>  
  16.   

²         WEB-INF/web.xml:配置spring监听及DispatcherServlet

  1. <context-param>  
  2.   
  3.         <param-name>contextConfigLocation</param-name>  
  4.   
  5.         <param-value>  
  6.   
  7.             /WEB-INF/application-context.xml   
  8.   
  9.         </param-value>  
  10.   
  11.     </context-param>  
  12.   
  13.     
  14.   
  15.     <listener>  
  16.   
  17.         <listener-class>  
  18.   
  19.             org.springframework.web.context.ContextLoaderListener   
  20.   
  21.         </listener-class>  
  22.   
  23.     </listener>  
  24.   
  25.     
  26.   
  27. <servlet>  
  28.   
  29.         <servlet-name>service</servlet-name>  
  30.   
  31.         <servlet-class>  
  32.   
  33.             org.springframework.web.servlet.DispatcherServlet   
  34.   
  35.         </servlet-class>  
  36.   
  37.         <load-on-startup>1</load-on-startup>  
  38.   
  39.     </servlet>  
  40.   
  41.     
  42.   
  43.     <servlet-mapping>  
  44.   
  45.         <servlet-name>service</servlet-name>  
  46.   
  47.         <url-pattern>/service/*</url-pattern>  
  48.   
  49.     </servlet-mapping>  
  50.   

说明:不了解为什么这么配置的可以去看看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的代理

  1. <bean id="httpService"  
  2.   
  3. class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">  
  4.   
  5.         <property name="serviceUrl">  
  6.   
  7.             <value> http://${serviceName}:${port}/${contextPath}/service/httpService   
  8.   
  9. </value>  
  10.   
  11.         </property>  
  12.   
  13.         <property name="serviceInterface"  
  14.   
  15.             value="com.netqin.baike.service.UcService">  
  16.   
  17.         </property>  
  18.   
  19. </bean>  
  20.   

说明:客户端使用HttpInvokerProxyFactoryBean代理客户端向服务器端发送请求,请求接口为UcService的服务

注意:需要修改serviceUrl为实际的服务器地址

²         WEB-INF/web.xml:配置spring监听

如果项目没有spring环境,则需要在web.xml中加入对spring的支持

  1. <context-param>  
  2.   
  3.         <param-name>contextConfigLocation</param-name>  
  4.   
  5.         <param-value>  
  6.   
  7.             /WEB-INF/application-context.xml   
  8.   
  9.         </param-value>  
  10.   
  11.     </context-param>  
  12.   
  13.     
  14.   
  15.     <listener>  
  16.   
  17.         <listener-class>  
  18.   
  19.             org.springframework.web.context.ContextLoaderListener   
  20.   
  21.         </listener-class>  
  22.   
  23. </listener>  
  24.   

 

3.       访问服务方法

u         读取spring上下文,以远程调用getUserInfobyName方法为例

²         在jsp,servlet,action等等文件中

  1. UcService service = (UcService) WebApplicationContextUtils   
  2.   
  3.         .getRequiredWebApplicationContext(   
  4.   
  5.             request.getSession().getServletContext()).getBean(   
  6.   
  7.             "httpService");   
  8.   
  9. UserInfo user = service.getUserInfobyName("hanqunfeng");   
  10.   

 ²         如果不想配置spring运行环境,可以使用如下方式:

  1. ApplicationContext applicationContext    
  2.   
  3. new FileSystemXmlApplicationContext("classpath:application-context.xml");   
  4.   
  5. service = (UcService) applicationContext.getBean("httpService");   

u         依赖注入,远程调用recordLog方法为例

²         在WEB-INF/application-context.xml中加入如下配置:

  1. <bean id="abc" class="com.netqin.test.abc">  
  2.   
  3.         <property name="service">  
  4.   
  5.             <ref bean="httpService" />  
  6.   
  7.         </property>  
  8.   
  9. </bean>  
  10.   

²         为com.netqin.test.abc中加入对service的set方法:

  1. private UcService service;   
  2.   
  3.     public void setService(UcService service){   
  4.   
  5.         this.service = service;   
  6.   
  7.     }   
  8.   
  9.     
  10.   
  11.     public String recordUserLog(String username,String point,String operate,String desc){   
  12.   
  13.         String result = service.recordLog(username, point, operate, desc);   
  14.   
  15.         return result;   
  16.   
  17. }   
  18.   
分享到:
评论
3 楼 Kent_Mu 2013-11-04  
挺好,不过需要依赖于java
2 楼 402230366 2013-07-17  
好文章,可不可以被无情的转载
1 楼 wang520 2012-09-17  
    呵呵,不错。顶。顶。顶。。。

相关推荐

    Spring HttpInvoker的封装

    Spring HttpInvoker简介** HttpInvoker是Spring Remoting(远程调用)的一种实现方式,它基于HTTP协议,通过序列化和反序列化Java对象来实现远程方法调用。相比于RMI(远程方法调用)和其他远程调用技术,...

    Spring HttpInvoker介绍

    公司内部讲义,比较了SOA,RMI和Spring HttpInvoker。并介绍了Spring HttpInvoker的基本使用方法。

    Spring HttpInvoker

    Spring HttpInvoker,是一套基于Maven+Spring+SpringMVC+MyBatis框架,还包含了Invoker的客户端及服务器端的demo实例

    使用httpInvoker提供远程服务

    HttpInvoker是Spring框架的一部分,它允许开发者使用HTTP协议进行远程方法调用,而不需要额外的类库。与Hessian等轻量级通信协议不同,HttpInvoker依赖于Java的序列化机制来处理方法的参数和返回值。 **14.7.1 输出...

    Spring HttpInvoker 初学实例

    org.springframework.remoting.httpinvoker最基本的实现例子,这是3个eclipse的JavaEE工程,全部导入即可,能运行。 初学可以轻松了解Spring HttpInvoker 的结构和使用。

    Java Spring2.5 Remote Invoke HTTP Invoker

    一、Spring HTTP Invoker简介 HTTP Invoker是Spring框架的一个组件,它提供了透明的远程方法调用能力,通过HTTP POST请求将Java对象序列化为字节流,然后在网络中传输,到达目标服务器后反序列化并执行相应的方法。...

    spring httpInvoker示例

    在本文中,我们将深入探讨如何使用Spring框架中的HTTP Invoker组件进行远程方法调用(RMI)的实例。HTTP Invoker是Spring框架提供的一种轻量级远程调用解决方案,它利用HTTP协议在客户端和服务端之间传输Java对象。...

    springboot-httpinvoker-demo.zip

    HTTP Invoker是Spring框架提供的一个基于HTTP协议的远程调用机制,它通过序列化对象并将其作为HTTP请求的body发送到远程服务器,然后由服务器反序列化并执行相应的方法。这种方式相比于传统的RMI或者Hessian,更加...

    spring-httpinvoker-demo

    Spring HTTP Invoker是spring框架中的一个远程调用模型,执行基于HTTP的远程调用,也就是说,可以通过防火墙,并使用java的序列化机制在网络间传递对象。客户端可以很轻松的像调用本地对象一样调用远程服务器上的...

    Spring 实现远程访问详解——httpinvoker

    Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和返回值是比较复杂的,通过httpInvoker有巨大的优势。 1. 远程访问流程 1) 服务端定义服务接口 2) 服务端实现服务接口 3) 暴露服务...

    Spring的HttpInvoker使用示例 (可下载源码)

    NULL 博文链接:https://lggege.iteye.com/blog/369151

    http invoker 做post测试

    3. **配置HTTP Invoker**:在服务端配置Spring,启用HTTP Invoker的支持,将接口绑定到特定的URL路径上,以便客户端可以访问。 4. **客户端构建请求**:在客户端,我们需要创建一个HTTP Invoker的代理对象,该对象...

    Http Invoker

    **Http Invoker:接口测试工具详解** Http Invoker是一款用于接口测试的工具,它允许开发者对Web服务进行调用和测试,验证API的功能和性能。虽然在某些用户看来,Http Invoker可能并不是最易用或者功能最全面的工具...

    Java Spring1.2 Remote Invoke HTTP Invoker

    Java Spring 1.2 远程调用HTTP Invoker是一个基于HTTP协议的远程服务调用框架,它是Spring框架的一部分,允许应用通过HTTP协议进行服务间的通信。这种通信方式相对于RMI(Remote Method Invocation)等其他远程调用...

    基于Spring的HttpInvoker实现改写egova_invoker.zip

    基于Spring的HttpInvoker实现改写服务器端调用: HttpInvoker.invoker 方法,设置InvokerProcess处理客户端调用: ProxyFactory.proxy 方法,生成接口的代理对象,直接调用方法客户端和服务器端的接口和实体类要...

    用Http Invoker实现RCP客户端与后台的交互

    `Http Invoker`是Spring框架提供的一种基于HTTP协议的RPC实现,主要用于Java应用程序之间进行服务调用。本文将深入探讨如何使用Http Invoker实现RCP客户端与后台的交互,以及相关知识点。 1. **Http Invoker的基本...

    Hessian 、 HttpInvoker 、 XFire 、 Axis

    HttpInvoker主要面向Spring应用程序,易于集成,但相比Hessian,其数据传输效率较低,因为HTTP协议本身较重,且Java序列化也相对消耗资源。 XFire(后来被Apache CXF吸收)是一款基于XML的Web服务框架,它支持多种...

    改造Spring的HttpInvoker, 去掉对Bean的XML配置文件的依赖

    NULL 博文链接:https://lggege.iteye.com/blog/404124

    Eclipse工程Http Invoker Service & Client

    Http Invoker是Spring框架的一个组件,允许在分布式环境中通过HTTP协议透明地调用Java对象的方法,提供了一种轻量级的RPC(Remote Procedure Call)实现。 **Http Invoker服务端(Service)** 在Http Invoker...

    Java学习之路-Spring的HttpInvoker学习

    Hessian和Burlap都是基于HTTP的,他们...  Spring开发团队意识到RMI服务和基于HTTP的服务之前的空白,Spring的HttpInvoker应运而生。  Spring的HttpInvoker,它基于HTTP之上提供RPC,同时又使用了Java的对象序列化机

Global site tag (gtag.js) - Google Analytics