微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

HESSIAN的技术实现简介

  • 基本介绍

Hessian一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI功能。采用二进制RPC协议进行数据传输。

 

  • 实现原理

依托HTTP协议,在其上发送二进制数据信息,其使用的ContentTypex-application/hessian。

客户端代理用户的请求,将调用方法和参数值进行二进制编码,通过指定的URL打开HTTP连接,将数据传输到服务器端。服务器端URL对应的Servlet接收到数据后,进行解析,交给具体实现类完成调用,然后将返回值编码发回客户端。

  • 客户端实现

通过HessianProxyFactory.create()方法,产生用户指定Interface的实例。具体实例的实现由JDK的Proxy代理机制来负责。在Proxy生成实例时,传入的InvocationHandler接口实例为HessianProxy。

当客户端调用时,所有的操作都由HessianProxy来负责:主要是将调用方法、参数写入到URL指定的连接中。然后对返回的数据进行解析,返回给用户

其主要方法实现:

public Object invoke(Object proxy,Method method,Object []args) {
          ....
               conn = sendRequest(mangleName,args);
                is =getInputStream(conn);
               ....
                int code =is.read();
              .....
}


  • 服务器实现

服务器端的入口类为HessianServlet,它通过ServletConfig中的home-class参数,获取具体功能的实现类名,并生成实例。通过home-api参数,获取实现的接口类。然后接受客户端的POST请求,将请求中的数据交给HessianSkeleton处理。

是服务器端的核心处理类,它持有具体实现类实例,并将指定的类中的方法全部进行缓存。其处理调用请求的过程如下:

1.      从请求中解析出方法(string)和参数值。

2.      从缓存中获取到对应的方法Method),然后调用实例中的对应实现方法method.invoke(service,values)

3.      如果获取不到对应的方法(即接口中没有定义),将向连接中写入错误信息:NoSuchMethodException

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐