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
- <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 基本篇 【转】
- Hessian基本篇
- hessian(一)--基本使用
- Hessian的基本使用
- Hessian学习(1)——基本使用
- java中使用Hessian基本步骤
- hessian (Java 篇)
- Hessian
- hessian
- Hessian
- Hessian
- hessian
- Hessian
- Hessian
- Hessian
- Hessian
- Hessian
- Hessian
- jsp 相对路径问题 (转)
- blazeds主动推技术
- c++中怎么判断一个string类型的字符串变量是否为数字?
- Linux+Apache+Tomcat7
- 腾讯附加题
- Hessian 基本篇 【转】
- 绝对经典的 xml 工具 完美破解
- MFC 查找一个进程 打开进程 关闭进程
- java web项目异常处理办法(基于struts2的项目)
- 目标到像点的坐标变换
- SVN提交失败 can't open file‘\db\txn-current-lock’ 拒绝访问
- [4月16日的脚本] 检验磁盘分区是否包含正确的4KB对齐 (VBScript)
- 海量数据处理面试题整理
- SSL介绍