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>