您的位置:首页 > 其它

hessian 入门

2015-07-26 22:13 441 查看
Hessian 是一个序列化协议, 他的优点在于比 Java 原生的对象序列化/反序列化速度更快, 序列化出来以后的数据更小.

序列化协议跟应用层协议无关, 可以将 Hessian 序列化以后的数据放在 HTTP Body 里, 也可以放在 DUBBO 里, 或者直接用 Socket 传输。

hessian是一个采用二进制格式传输的服务框架,相对传统soap web service,更轻量,更快速。

作为入门,我们定义一个helloworld级别的例子

一、 定义接口(客户端、服务器端使用)

如:

public interface HelloService {
public String sayHello(String name);
}


二、服务器端实现

public class HelloServiceImpl implements HelloService {

@Override
public String sayHello(String message) {
return "hello," + message;
}
}


三、 接口发布

在web.xml 中添加如下

<servlet>
<servlet-name>hessian-service</servlet-name>
<servlet-class>
com.caucho.hessian.server.HessianServlet
</servlet-class>
<init-param>
<param-name>home-class</param-name>
<param-value>
服务实现类
org.ifly.edu.hessian.hello.HelloServiceImpl
</param-value>
</init-param>
<init-param>
<param-name>home-api</param-name>
服务接口
<param-value>org.ifly.edu.hessian.hello.HelloService</param-value>
</init-param>
</servlet>

<servlet-mapping>
<servlet-name>hessian-service</servlet-name>
<url-pattern>/hessian</url-pattern>
</servlet-mapping>


这样就可以访问sayHello 接口了

四、客户端访问

public class ServiceTest {

@Test
public void testService() throws MalformedURLException {

String url = "http://localhost:8080/techStudy/hessian";
System.out.println(url);

HessianProxyFactory factory = new HessianProxyFactory();
HelloService helloService = (HelloService) factory.create(HelloService.class, url);
System.out.println(helloService.sayHello("pangzhw"));

}
}


ok,代码写完。

我们直接启动服务端的server。然后执行客户端,运行结果,如下

hello,pangzhw
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: