Hessian 基本篇 【转】

来源:互联网 发布:java多线程是多核吗 编辑:程序博客网 时间:2024/05/21 07:04


http://a123159521.iteye.com/blog/741820


Spring + Hessian

背景;
优点:【摘自网上】hessian类似于Webservice,但是它不使用soap协议,它把协议报文封装到http封包中,通过HTTP信道传输。是一种高效简洁的远程调用框架,它采用的是二进制RPC协议(Binary),具有轻量、传输量小、平台无关的特点,特别适合于目前网络带宽比较小的手机网络应用项目。Hessian是通过servlet提供远程服务,完全使用动态代理来实现的,推荐采用面向接口编程,因此,Hessian服务建议通过接口暴露。hessian已经支持Java,Flash/Flex,Python,C++,.NET C#,D,Erlang,PHP,Ruby,Objective C。其中我最喜欢的就是它不需要我们与xml“打交道”,直接操作对象,省去了很多麻烦。
缺点:如果service层中返回的对象是复杂对象,使用它就会削弱Hessian的传输量小的优点,而且也会增加Hessian客户端的代码量。既然它是把对象序列化为二进制流的形式在http信道中传输,那么对于安全性高的应用不应该采用hessian(比如网上支付等)、
官司方简介:Hessian 是一个二进制协议,提供web 服务就像创建Servlet一样简单. 使用服务就像使用JDK代理接口一样简单
com.caucho.hessian.client
com.caucho.hessian.server  并不是必须的,可以使用简单的客户端,比如applets.


如何开发Hessian:
1. 下载Spring[2.56]包和Hessian[3.1.6包
2. 新建一个项目,并把spring和Hessian的架包加入到项目当中.
3. 新建web.xml,并加入Hessian和Spring支持,配置如下:
加载Spring
Java代码  收藏代码
  1. <context-param>  
  2.         <param-name>contextConfigLocation</param-name>  
  3.         <param-value>/WEB-INF/remoting-servlet.xml</param-value>  
  4.     </context-param>  
  5.   
  6.     <listener>  
  7.         <listener-class>  
  8.             org.springframework.web.context.ContextLoaderListener  
  9.         </listener-class>  
  10.     </listener>  

拦截请求,使用Hessian发布服务
Java代码  收藏代码
  1. <servlet>  
  2. <!--  配置Servlet名,后面根据该名完成远程服务映射-->  
  3. <servlet-name>remoting</servlet-name>  
  4. <!--  Hessian远程服务需要HessianServlet暴露Hehes-->  
  5. <servlet-class>  
  6.             <!--集成到Spring 在Spring-webmvc-2.5.6里面-->  
  7.                     org.springframework.web.servlet.DispatcherServlet  
  8.                 </servlet-class>  
  9.             <!--  随应用启动而启动 -->  
  10.                 <load-on-startup>1</load-on-startup>  
  11. </servlet>  
  12.   
  13.         <!--  映射Servlet的url,该Servlet的url就是Hessian服务名-->  
  14. <servlet-mapping>  
  15. <servlet-name>remoting</servlet-name>  
  16. <!--  远程服务名为hessianService-->  
  17. <url-pattern>/remoting/*</url-pattern>  
  18.             </servlet-mapping>  

remoting-servlet.xml配置如下:
Java代码  收藏代码
  1. <bean id="hello" class="com.module.impl.HelloImpl"/>   
  2.     <bean name="/Hello"   
  3.     class="org.springframework.remoting.caucho.HessianServiceExporter">  
  4.         <!— Hessian服务的实现类-->   
  5.         <property name="service" >  
  6.                 <ref bean="hello" />  
  7.         </property>   
  8.         <!--  Hessian服务的接口-->   
  9.         <property name="serviceInterface" value="com.module.Hello"/>    
  10.     </bean>  

现在我们准备在客户端连接这个业务。我们使用BeanNameUrlHandlerMapping,就不需要指定处理器映射将请求(url)映射到业务上,因此业务提供在
${ServletMapping}/Hello上。
com.module.Hello接口定义:
Java代码  收藏代码
  1. public interface Hello {  
  2.     public String hello();   
  3. }  

com.module.HelloImpl实现类定义:
Java代码  收藏代码
  1. public class HelloImpl implements Hello {  
  2.     public String hello() {  
  3.         return "hello "  + "欢迎学习Hessian";   
  4.     }  
  5. }  

很简单的一个服务,把程序发布的Web服务器下,然后启动服务.
访问网址: http://localhost/Hessian/remoting/Hello
你会得到一个错误信息: HTTP Status 405 - HessianServiceExporter only supports POST requests说明已经发布成功!.
Hessian缺少的,服务列表的提供,这个可以自己写一个方法展示全部的Hessian服务,并写TestCase来测试所有服务,最后把服务发布到服务器上.
因为Hessian是基于Binary-RPC协议实现的,他的请求是通过Hessian本身提供的API来发起请求.并通过其自定义的串行化机制将请求信息序列化,产生二进制流,其基于HTTP协议进行传输,他的响应是根据Hessian提供的API接收请求,Hessian根据其私有的串行化机制将请求进行反序列化,传递给使用者时已经是相应的请求信息对象了. 处理完毕后直接返回,hessian将结果对象进行序列化,传输至调用端。

下图展示了Hessian是怎么发送对象到返回对象的数据流:
原创粉丝点击