Hessian 基本篇

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
<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>/WEB-INF/remoting-servlet.xml</param-value>
	</context-param>

	<listener>
		<listener-class>
			org.springframework.web.context.ContextLoaderListener
		</listener-class>
	</listener>

拦截请求,使用Hessian发布服务
<servlet>
<!--  配置Servlet名,后面根据该名完成远程服务映射-->
<servlet-name>remoting</servlet-name>
<!--  Hessian远程服务需要HessianServlet暴露Hehes-->
<servlet-class>
			<!--集成到Spring 在Spring-webmvc-2.5.6里面-->
					org.springframework.web.servlet.DispatcherServlet
			    </servlet-class>
			<!--  随应用启动而启动 -->
			    <load-on-startup>1</load-on-startup>
</servlet>

		<!--  映射Servlet的url,该Servlet的url就是Hessian服务名-->
<servlet-mapping>
<servlet-name>remoting</servlet-name>
<!--  远程服务名为hessianService-->
<url-pattern>/remoting/*</url-pattern>
			</servlet-mapping>


remoting-servlet.xml配置如下:
<bean id="hello" class="com.module.impl.HelloImpl"/> 
	<bean name="/Hello" 
	class="org.springframework.remoting.caucho.HessianServiceExporter">
		<!— Hessian服务的实现类--> 
        <property name="service" >
        		<ref bean="hello" />
        </property> 
        <!--  Hessian服务的接口--> 
        <property name="serviceInterface" value="com.module.Hello"/>  
	</bean>


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

com.module.HelloImpl实现类定义:
public class HelloImpl implements Hello {
	public String hello() {
		return "hello "  + "欢迎学习Hessian"; 
	}
}

很简单的一个服务,把程序发布的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是怎么发送对象到返回对象的数据流:
Hessian 基本篇

你可能感兴趣的:(spring,应用服务器,servlet,网络应用,网络协议)