Hessian 调用流程

Posted 小泽泽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hessian 调用流程相关的知识,希望对你有一定的参考价值。

服务端流程

   采用spring mvc+hessian形式,解析请求处理器使用BeanNameUrlHandlerMapping.

   1.创建一个类OurServiceExporter,继承HessianExporter类,实现HttpRequestHandler接口(spring mvc),

   2.将请求转发至OurServiceExporter这个类,并配置service以及serviceInterface属性:

  <bean id="defaultHandlerMapping" class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
  <!-- 查询余额 -->
  <bean id="aaImpl" class="com.lot.account.hess.impl.AccountAmountImpl"/>
  <bean name="/accAmount" class="com.lot.hess.OurServiceExporter">
  <property name="service" ref="aaImpl"/>
  <property name="serviceInterface" value="com.lot.init.hess.IAccountAmount"/>
  </bean>

   3. 请求进来后,调用父类HessianExporter的invoke方法,将request的输入流以及输出流作为参数传入.

     

  4.在初始化HessianExporter的时候,会预先创建HessianSkeleton,并把传入一个代理service(spring的ProxyFactory实现代理)以及serviceInterface作为构造参数

      

   5. HessianExporter的invoke方法将输入流转换为AbstractHessianIuput(暂命为in),将输出流转换为AbstractHessianOutput(暂命为out),设置输入流输出流的序列化实现类调用HessianSkeleton的invoke方法

      

  6.HessianSkeleton的invoke方法,从in读取方法名method,参数长度,并将参数反序列化,使用method.invoke调用方法,并将返回值使用out写回

    

     

    具体细节,还得多看看源码,这里只是粗略的流程,写得不好,请担待。

以上是关于Hessian 调用流程的主要内容,如果未能解决你的问题,请参考以下文章

远程调用——hessian使用入门

RPC远程调用 之 Hessian

SpringMVC整合Hessian远程服务调用

SpringMVC整合Hessian远程服务调用

Hessian

hessian(转)