浏览 4598 次
锁定老帖子 主题:关于hessian的一些认识
该帖已经被评为新手帖
|
|
---|---|
作者 | 正文 |
发表时间:2009-12-17
最后修改:2009-12-18
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.1 Content-Type: x-application/hessian User-Agent: Java/1.5.0_15 Host: 127.0.0.1:8080 Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2 Connection: keep-alive Transfer-Encoding: chunked 以下是请求中的方法和参数,经过hessian的转化这里不再贴了 返回内容格式如下: HTTP/1.1 200 OK Server: Apache-Coyote/1.1 Content-Type: application/x-hessian Transfer-Encoding: chunked Date: Thu, 17 Dec 2009 08:39:13 GMT 以下是请求方法的返回结果,经过hessian的转化这里不再贴了 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2010-01-20
它不支持方法的重载
|
|
返回顶楼 | |
发表时间:2010-01-22
正是因为在客户端他把javaBean都转化为hashmap传过去的,所以就不支持方法重载。(如果两个方法就JavaBean参数不一样,无法确定是调用哪个方法)
|
|
返回顶楼 | |
发表时间:2010-01-24
还有一个是同一个接口中的名字不能相同。
|
|
返回顶楼 | |
发表时间:2010-01-25
允许方法重载 是HessianProxyFactory调用 setOverloadEnabled. |
|
返回顶楼 | |
发表时间:2010-02-18
不太清楚hessian是否有好的客户端生成工具。
如果开发人员希望进行大量跨语言调用,比如C# Client调用Java Server,将遇到非常麻烦的客户端生成问题。 手工书写很容易产生server/client不一致问题。 而使用webservice则通常有成熟的客户端生成工具,不会发生这样的问题。 不知现在是否有较好的解决方案。 |
|
返回顶楼 | |
发表时间:2010-02-22
protobuf支持
|
|
返回顶楼 | |