- 基本介绍
Hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能。采用二进制RPC协议进行数据传输。
- 实现原理
依托HTTP协议,在其上发送二进制数据信息,其使用的ContentType为x-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);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。