博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用Hessian如何实现Webservice
阅读量:7061 次
发布时间:2019-06-28

本文共 14906 字,大约阅读时间需要 49 分钟。

利用Hessian如何实现Webservice

[ 大] [ 中] [ 小] 发布人:   发布日期:2012-08-18 14:02  共966人浏览
Hessian是 一个轻量级的remoting on http工具,采用的是Binary RPC协议,所以它很适合于发送二进制数据,同时又具有防火墙穿透能力。Hessian一般是通过Web应用来提供服务,因此非常类似于平时我们用的 WebService。只是它不使用SOAP协议,但相比webservice而言更简单、快捷。
Hessian官网:http://hessian.caucho.com/
Hessian可 通过Servlet提供远程服务,需要将匹配某个模式的请求映射到Hessian服务。也可Spring框架整合,通过它的 DispatcherServlet可以完成该功能,DispatcherServlet可将匹配模式的请求转发到Hessian服务。Hessian的 server端提供一个servlet基类, 用来处理发送的请求,而Hessian的这个远程过程调用,完全使用动态代理来实现的,,建议采用面向接口编程,Hessian服务通过接口暴露。
Hessian处理过程示意图:
客户端——>序列化写到输出流——>远程方法(服务器端)——>序列化写到输出流 ——>客户端读取输入流——>输出结果
下面详细介绍最常用的两种方式实现Hessian提供webservice:
纯Hessian实现
配合Spring框架实现
在开始之前当然需要到官网上下载相关的lib包,放入项目的/WEB-INF/lib/下
【一】、纯Hessian实现步骤:
1.基本代码
首先编写一个服务的接口类:HelloHessian.java
Java代码
1.           package michael.hessian;     
2.           import java.util.List;     
3.           import java.util.Map;     
4.               
5.           /**    
6.            * @author michael    
7.            *     
8.            */    
9.           public interface HelloHessian {     
10.           
11.           String sayHello();     
12.           
13.           MyCar getMyCar();     
14.           
15.           List myLoveFruit();     
16.           
17.           Map
 myBabays();     
18.           
19.       }   
一个java bean文件MyCar.java:
Java代码
1.           package michael.hessian;     
2.               
3.           import java.io.Serializable;     
4.               
5.           /**    
6.            * @author michael    
7.            *     
8.            */    
9.           public class MyCar implements Serializable {
10.           
11.           /**    
12.            *     
13.            */    
14.           private static final long serialVersionUID = 4736905401908455439L;
15.           
16.           private String carName;     
17.           
18.           private String carModel;     
19.           
20.           /**    
21.            * @return the carName    
22.            */    
23.           public String getCarName() {     
24.               return carName;     
25.           }     
26.           
27.           /**    
28.            * @return the carModel    
29.            */    
30.           public String getCarModel() {     
31.               return carModel;     
32.           }     
33.           
34.           /**    
35.            * @param pCarName the carName to set    
36.            */    
37.           public void setCarName(String pCarName) {
38.               carName = pCarName;     
39.           }     
40.           
41.           /**    
42.            * @param pCarModel the carModel to set    
43.            */    
44.           public void setCarModel(String pCarModel) {
45.               carModel = pCarModel;     
46.           }     
47.           
48.           /**    
49.            * @see java.lang.Object#toString()    
50.            * @return    
51.            */    
52.           @Override    
53.           public String toString() {     
54.               return "my car name:[" + this.carName + "] model:[" + this.carModel
55.                       + "].";     
56.           }     
57.           
58.       }   
服务端接口的实现类:HelloHessianImpl.java
Java代码
1.           package michael.hessian.impl;     
2.               
3.           import java.util.ArrayList;     
4.           import java.util.HashMap;     
5.           import java.util.List;     
6.           import java.util.Map;     
7.               
8.           import michael.hessian.HelloHessian;     
9.           import michael.hessian.MyCar;     
10.           
11.       /**    
12.        * @author michael    
13.        *     
14.        */    
15.       public class HelloHessianImpl extends HessianServlet implements HelloHessian {
16.           
17.           public MyCar getMyCar() {     
18.               MyCar car = new MyCar();     
19.               car.setCarName("阿斯顿·马丁");     
20.               car.setCarModel("One-77");     
21.               return car;     
22.           }     
23.           
24.           public Map
 myBabays() {     
25.               Map
 map = new HashMap
();     
26.               map.put("son", "孙吴空");
27.               map.put("daughter", "孙小美");
28.               return map;     
29.           }     
30.           
31.           public List myLoveFruit() {     
32.               List list = new ArrayList();     
33.               list.add("apple");     
34.               list.add("kiwi");     
35.               list.add("orange");     
36.               return list;     
37.           }     
38.           
39.           public String sayHello() {     
40.               return "welcom to Hessian";
41.           }     
42.           
43.       }   
2.配置文件web.xml修改
在web.xml配置文件里增加如下信息:
Xml代码
1.           
    
2.                   
HelloHessian
servlet-name>    
3.                   
    
4.                       com.caucho.hessian.server.HessianServlet     
5.                   
servlet-class>    
6.                   
    
7.                       
home-class
param-name>    
8.                       
michael.hessian.impl.HelloHessianImpl
param-value>    
9.                   
init-param>    
10.               
    
11.                   
home-api
param-name>    
12.                   
michael.hessian.HelloHessian
param-value>    
13.               
init-param>    
14.               
1
load-on-startup>    
15.           
servlet>    
16.           
    
17.               
HelloHessian
servlet-name>    
18.               
/HessianService
url-pattern>    
19.           
servlet-mapping>    
20.           
    
3.java
客户端验证
Java
代码
1.           package michael.hessian.client;     
2.               
3.           import java.net.MalformedURLException;     
4.           import java.util.Map;     
5.               
6.           import michael.hessian.HelloHessian;     
7.           import michael.hessian.MyCar;     
8.               
9.           import com.caucho.hessian.client.HessianProxyFactory;     
10.           
11.       /**    
12.        * @author michael    
13.        *    
14.        */    
15.       public class HessianClientTest {     
16.           
17.           /**    
18.            * @param args    
19.            */    
20.           public static void main(String[] args) {     
21.               String url = "http://localhost:8082/J2EE_sjsky/HessianService";     
22.               HessianProxyFactory factory = new HessianProxyFactory();     
23.               try {     
24.                   HelloHessian hello = (HelloHessian) factory.create(     
25.                           HelloHessian.class, url);     
26.                   System.out.println(hello.sayHello());     
27.           
28.                   MyCar car = hello.getMyCar();     
29.                   System.out.println(car.toString());     
30.           
31.                   for (Map.Entry
 entry : hello.myBabays().entrySet()) {     
32.                       System.out.println(entry.getKey() + "   " + entry.getValue());     
33.                   }     
34.           
35.                   for (String str : hello.myLoveFruit()) {     
36.                       System.out.println(str);     
37.                   }     
38.           
39.               } catch (MalformedURLException e) {     
40.                   e.printStackTrace();     
41.               }     
42.           
43.           }     
44.           
45.       }    
运行结果如下:
Java
代码
1.           welcom to Hessian     
2.           my car name:[阿斯顿·马丁] model:[One-77].     
3.           daughter   孙小美     
4.           son   孙吴空     
5.           apple     
6.           kiwi     
7.           orange   
【二】、spring+hessian 实现服务端:
1.
基本代码见上面的demo
2.
修改配置文件
在web.xml,增加内容如下:
Xml
代码
1.           
    
2.                   
springhessian
servlet-name>    
3.                   
    
4.                       org.springframework.web.servlet.DispatcherServlet     
5.                   
servlet-class>    
6.                       
7.               
8.                   class="org.springframework.remoting.caucho.HessianServiceExporter">    
9.                       
10.               
11.                   
12.               
13.                   value="michael.hessian.HelloHessian" />    
14.           
bean>    
15.       
beans>  
3.java客户端验证
和上面的例子相似,只需要把访问的url替换成新的即可如下:
Java
代码
1.           String url=http://localhost:8082/J2EE_sjsky/springhessian/helloHessianService
运行结果和上面例子一样。
4.spring
配置客户端
增加一个spring的bean配置文件hessian-client.xml
Xml
代码
1.           
2.           >    
3.           
    
4.               
5.                   class="org.springframework.remoting.caucho.HessianProxyFactoryBean">    
6.                   
7.                       
    
8.                           http://localhost:8082/J2EE_sjsky/springhessian/helloHessianService     
9.                       
value>    
10.               
property>    
11.               
12.                   value="michael.hessian.HelloHessian" />    
13.           
bean>    
14.       
beans>    
测试代码HessianSpringClient.java:
Java
代码
1.           package michael.hessian.client;     
2.               
3.           import java.util.Map;     
4.               
5.           import michael.hessian.HelloHessian;     
6.           import michael.hessian.MyCar;     
7.               
8.           import org.springframework.context.ApplicationContext;     
9.           import org.springframework.context.support.ClassPathXmlApplicationContext;     
10.           
11.       /**    
12.        * @author michael    
13.        *     
14.        */    
15.       public class HessianSpringClient {     
16.           
17.           /**    
18.            * @param args    
19.            */    
20.           public static void main(String[] args) {     
21.               try {     
22.                   ApplicationContext context = new ClassPathXmlApplicationContext(     
23.                           "hessian-client.xml");     
24.           
25.                   HelloHessian hello = (HelloHessian) context     
26.                           .getBean("helloHessianClient");     
27.           
28.                   System.out.println(hello.sayHello());     
29.           
30.                   MyCar car = hello.getMyCar();     
31.                   System.out.println(car.toString());     
32.           
33.                   for (Map.Entry
 entry : hello.myBabays().entrySet()) {     
34.                       System.out.println(entry.getKey() + "   " + entry.getValue());     
35.                   }     
36.           
37.                   for (String str : hello.myLoveFruit()) {     
38.                       System.out.println(str);     
39.                   }     
40.               } catch (Exception e) {     
41.                   e.printStackTrace();     
42.               }     
43.           
44.           }     
45.           
46.       }   
运行结果和上面完全一致。
5.com.caucho.hessian.io.HessianProtocolException: expected string at 0x6d
异常处理
我在spring+hessian整合测试过程中,客户端调用时,发生了异常,而服务端错误内容如下:
Java
代码
1.           2011-4-25 16:14:44 org.apache.catalina.core.StandardWrapperValve invoke
2.           严重: Servlet.service() for servlet remoting threw exception     
3.           com.caucho.hessian.io.HessianProtocolException: expected string at 0x6d    
4.               at com.caucho.hessian.io.Hessian2Input.error(Hessian2Input.java:2882)     
5.               at com.caucho.hessian.io.Hessian2Input.expect(Hessian2Input.java:2830)     
6.               at com.caucho.hessian.io.Hessian2Input.readString(Hessian2Input.java:1362)     
7.               at com.caucho.hessian.io.Hessian2Input.readMethod(Hessian2Input.java:272)     
8.               at com.caucho.hessian.server.HessianSkeleton.invoke(HessianSkeleton.java:249)     
9.               at com.caucho.hessian.server.HessianSkeleton.invoke(HessianSkeleton.java:221)     
10.           at org.springframework.remoting.caucho.Hessian2SkeletonInvoker.invoke(Hessian2SkeletonInvoker.java:67)     
11.           at org.springframework.remoting.caucho.HessianServiceExporter.handleRequest(HessianServiceExporter.java:147)     
12.           at org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:49)     
13.           at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:819)     
14.           at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:754)     
15.           at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:399)     
16.           at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:364)     
17.           at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)     
18.           at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)     
19.           at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)     
20.           at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)     
21.           at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)     
22.           at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)     
23.           at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)     
24.           at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)     
25.           at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)     
26.           at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)     
27.           at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)     
28.           at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581)     
29.           at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)     
30.           at java.lang.Thread.run(Thread.java:619)   
 

转载地址:http://mdnll.baihongyu.com/

你可能感兴趣的文章
activiti学习资料(架构描述)
查看>>
概率图常见模型
查看>>
Android JNI编程(二)——C语言的基本数据类型,输出函数,输入函数
查看>>
使用SwingBench 对Oracle RAC DB性能 压力测试
查看>>
前端学Markdown
查看>>
easyui datagrid 行右键生成 动态获取(toolbar) 按钮
查看>>
Hibernate实体关系映射(OneToMany、ManyToOne双边)——完整实例
查看>>
get方式和set方式提交时乱码
查看>>
正则表达式
查看>>
JavaBean,List,Map转成json格式
查看>>
(原+转)Ubuntu16.04软件中心闪退及wifi消失
查看>>
Linux下高并发socket最大连接数所受的各种限制
查看>>
java 设计模式 -- 责任链模式
查看>>
ATL接口返回类型&&ATL接口返回字符串BSTR*
查看>>
51 Nod 1008 N的阶乘 mod P【Java大数乱搞】
查看>>
空间统计之七:中心要素
查看>>
自己写的一部分斗地主的程序,没有去写界面,临时是用黑框来显示的
查看>>
nginx学习1
查看>>
mysql批量删除相同前缀的表格
查看>>
HDU 5358 First One(枚举)
查看>>