打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
关于hessian的一些认识
Hessian是一个解耦合的远程调用包
1、hessian是基于http协议的,使用自己的序列化机制,这里和RMI不同,RMI是使用java的序列化机制,包路径不能改变。
2、Hessian中接口的包路径可以不一样,即:server端和client端的接口包路径可以不同(不知道类名可不可以不同),如:在server端开放接口为:com.topsoft.service.TestImpl在client端接收时为:com.topsoft.hessian.Test_Test
3、接口类的名字可以不一样,示例同上
4、远程调用hessian服务其实只需要一个接口,不需要依赖的entity。其中涉及到的实体,hessian以map形式来传递值
如:server端有方法:public TestEntity getObj(TestEntity entity);//其中TestEntity是一个测试实体。有三个简单的属性:name;pwd;key;
在client端可用如下方法调用:(当然客户端需要修改接口为 Map getObj(Map entity));
Map entity=new HashMap();
entity.put("name", "你好");
entity.put("pwd", "123");
entity.put("key", 123);
Map obj=test.getObj(entity);
注:如果在client端传实体,则必须与server端的实体一致。这里的实体需要继承Serializable接口,但是serialVersionUID 并不影响实体的一致性。
这里如果客户端接口修改为Object getObj(Object entity),会有两种情况,如果客户端CLASSAPTH存在TestEntity这个实体,则获得的是实体,如果不存在,则获得HashMap.

5、hessian传递Collection
Hessian对于容器的传递,如果client端容器中该对象类型在CLASSPATH中存在,则容器内是传递的对象,如果不存在,则被转换为HashMap对象。要注意:如果对象类型在CLASSPATH中存在,却想强转是会抛异常的。

6、hessian远程调用分析:
Hessian 的client远程调用时,其实是转化为http请求发送出(HttpURLConnection)去的,发送格式如下:
POST /test/testService HTTP/1.1Content-Type: x-application/hessianUser-Agent: Java/1.5.0_15Host: 127.0.0.1:8080Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2Connection: keep-aliveTransfer-Encoding: chunked以下是请求中的方法和参数,经过hessian的转化这里不再贴了


返回内容格式如下:
HTTP/1.1 200 OKServer: Apache-Coyote/1.1Content-Type: application/x-hessianTransfer-Encoding: chunkedDate: Thu, 17 Dec 2009 08:39:13 GMT以下是请求方法的返回结果,经过hessian的转化这里不再贴了



本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
关于Hessian的C++客户端与java服务端通信
HSF的原理分析
动态模型(Dynamic models)
教你认识Java应用的各个层级
什么是EJB
知识图谱 Recorder︱中文知识图谱API与工具、科研机构与算法框架
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服