最近项目使用远程调用时用到了hessian,对于hessian还是处于入门阶段,大概做个资料的整理和收集。
Hessian的介绍
Hessian简单、快捷。采用的是二进制RPC协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。
1、是基于什么协议实现的?
基于Binary-RPC协议实现。
2、怎么发起请求?
需通过Hessian本身提供的API来发起请求。
3、怎么将请求转化为符合协议的格式的?
Hessian通过其自定义的串行化机制将请求信息进行序列化,产生二进制流。
4、使用什么传输协议传输?
Hessian基于Http协议进行传输。
5、响应端基于什么机制来接收请求?
响应端根据Hessian提供的API来接收请求。
6、怎么将流还原为传输格式的?
Hessian根据其私有的串行化机制来将请求信息进行反序列化,传递给使用者时已是相应的请求信息对象了。
7、处理完毕后怎么回应?
处理完毕后直接返回,hessian将结果对象进行序列化,传输至调用端。
附件为一个简单的Hessian示例程序,包括client和server两个工程,simpleTest为简单的远程调用,springTest用于测试spring的注入。
注意事项:
1.导入相关的jar包。commons-logging-1.1.1.jar,hessian-3.2.0.jar,log4j-1.2.9.jar,spring.jar spring-web.jar spring-webmvc.jar
2.如果hessian传递的DO对象到远程,本地的DO对象所处的包的位置应该和服务端的一致,否则会报错。接口则可以不一样,只要远程的接口中含有本地所调用的方法。
3.spring中规定远程的配置文件为为remoting-servlet.xml,取别的名称会报错误,我也是看了spring的参考手册后才改正确的。
4.在struts 2中测试时开始老是报连接失败,因为hessian远程调用时以Servlet的方式进行访问的,而我又在服务端web.xml里面配置了struts2的拦截 /* ,因此servlet被拦截了(搞了我半天)
Hessian的介绍
Hessian简单、快捷。采用的是二进制RPC协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。
1、是基于什么协议实现的?
基于Binary-RPC协议实现。
2、怎么发起请求?
需通过Hessian本身提供的API来发起请求。
3、怎么将请求转化为符合协议的格式的?
Hessian通过其自定义的串行化机制将请求信息进行序列化,产生二进制流。
4、使用什么传输协议传输?
Hessian基于Http协议进行传输。
5、响应端基于什么机制来接收请求?
响应端根据Hessian提供的API来接收请求。
6、怎么将流还原为传输格式的?
Hessian根据其私有的串行化机制来将请求信息进行反序列化,传递给使用者时已是相应的请求信息对象了。
7、处理完毕后怎么回应?
处理完毕后直接返回,hessian将结果对象进行序列化,传输至调用端。
附件为一个简单的Hessian示例程序,包括client和server两个工程,simpleTest为简单的远程调用,springTest用于测试spring的注入。
注意事项:
1.导入相关的jar包。commons-logging-1.1.1.jar,hessian-3.2.0.jar,log4j-1.2.9.jar,spring.jar spring-web.jar spring-webmvc.jar
2.如果hessian传递的DO对象到远程,本地的DO对象所处的包的位置应该和服务端的一致,否则会报错。接口则可以不一样,只要远程的接口中含有本地所调用的方法。
3.spring中规定远程的配置文件为为remoting-servlet.xml,取别的名称会报错误,我也是看了spring的参考手册后才改正确的。
4.在struts 2中测试时开始老是报连接失败,因为hessian远程调用时以Servlet的方式进行访问的,而我又在服务端web.xml里面配置了struts2的拦截 /* ,因此servlet被拦截了(搞了我半天)