Hessian的简单 介绍:
Hessian是由caucho提供的一个基于binary-RPC实现的远程通讯library。
1、是基于什么协议实现的?
基于Binary-RPC协议实现。
2、怎么发起请求?
需通过Hessian本身提供的API来发起请求。
3、怎么将请求转化为符合协议的格式的?
Hessian通过其自定义的串行化机制将请求信息进行序列化,产生二进制流。
4、使用什么传输协议传输?
Hessian基于Http协议进行传输。
5、响应端基于什么机制来接收请求?
响应端根据Hessian提供的API来接收请求。
6、怎么将流还原为传输格式的?
Hessian根据其私有的串行化机制来将请求信息进行反序列化,传递给使用者时已是相应的请求信息对象了。
7、处理完毕后怎么回应?
处理完毕后直接返回,hessian将结果对象进行序列化,传输至调用端。
声明一个远程过程调用的服务如下:
很简单的一个POJO的接口
- package com.easyway.caucho.hessian.ws;
- import java.util.List;
- /**
- * 声明服务端相关的服务
- * @author longgangbai
- *
- */
- public interface IHessianService {
- public String getUserName();
- public List<String> getList();
- public void setGreeting(String greeting);
- public String hello();
- }
远程过程调用的服务的实现如下:
其实很简单只需要实现一个简单的类继承HessianServlet实现相关的服务接口。
- package com.easyway.caucho.hessian.ws;
- import java.util.ArrayList;
- import java.util.List;
- import com.caucho.hessian.server.HessianServlet;
- /**
- *
- * 在Hessian中服务端的必须继承HessianServlet类同时实现相关的服务的接口
- *
- * @author longgangbai
- *
- */
- public class HessianWS extends HessianServlet implements IHessianService{
- private String _greeting = "Hello, world";
- /**
- *
- */
- public void setGreeting(String greeting)
- {
- _greeting = greeting;
- }
- /**
- *
- */
- public String hello()
- {
- return _greeting;
- }
- /**
- *
- */
- public List<String> getList() {
- List<String> strList=new ArrayList<String>();
- strList.add("a"); strList.add("c");
- strList.add("b"); strList.add("d");
- strList.add("e"); strList.add("g");
- strList.add("h"); strList.add("j");
- strList.add("k"); strList.add("l");
- strList.add("q");
- return strList;
- }
- /**
- *
- */
- public String getUserName() {
- return _greeting;
- }
- }
客户端调用过程:
如下:
- package com.easyway.caucho.hessian.ws;
- import java.net.MalformedURLException;
- import com.caucho.hessian.client.HessianProxyFactory;
- /**
- * Hessian客户端测试代码
- * @author longgangbai
- *
- */
- public class HessianServiceWSClient {
- public static void main(String[] args) {
- String url = "http://localhost:8080/BurlapWS/remoting/hessianWs";
- HessianProxyFactory factory = new HessianProxyFactory();
- IHessianService basic;
- try {
- basic = (IHessianService) factory.create(IHessianService.class, url);
- System.out.println("hello(): " + basic.getUserName());
- System.out.println("getList(): " + basic.getUserName());
- } catch (MalformedURLException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- }
备注:HessianServlet是一个Servlet,实现Servlet相关的协议和类,所以需要在Web.xml配置如下:
一下摘自源代码:
- public class HessianServlet extends GenericServlet {
- private Logger _log = Logger.getLogger(HessianServlet.class.getName());
- private Class _homeAPI;
- private Object _homeImpl;
- private Class _objectAPI;
- private Object _objectImpl;
- private HessianSkeleton _homeSkeleton;
- private HessianSkeleton _objectSkeleton;
- private SerializerFactory _serializerFactory;
web.xml配置如下:
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app version="2.5"
- xmlns="http://java.sun.com/xml/ns/javaee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
- http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
- <servlet>
- <servlet-name>hessianWs</servlet-name>
- <servlet-class>com.easyway.caucho.hessian.ws.HessianWS</servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>hessianWs</servlet-name>
- <url-pattern>/remoting/hessianWs</url-pattern>
- </servlet-mapping>
- <welcome-file-list>
- <welcome-file>index.jsp</welcome-file>
- </welcome-file-list>
- </web-app>