- 浏览: 74803 次
- 性别:
- 来自: 西安
文章分类
Hessian是一个轻量级的remoting on http工具,使用简单的方法提供了RMI(Remote Method Invocation,远程方法调用)的功能。采用的是二进制RPC(Remote Procedure Call Protocol,远程过程调用协议)协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。
在进行基于Hessian的项目开发时,应当注意以下几点:
▲JAVA服务器端必须具备以下几点:
·包含Hessian的jar包。
·设计一个接口,用来给客户端调用。
·实现该接口的功能。
·配置web.xml,配好相应的servlet。
·对象必须实现Serializable 接口。
·对于复杂对像可以使用Map的方法传递。
▲客户端必须具备以下几点:
·java客户端包含Hessian.jar的包。
·具有和服务器端结构一样的接口。
·利用HessianProxyFactory调用远程接口。
下面是一个hessian的简单例子
场景1:服务端 客户端都不使用spring
Java服务器端:
环境:j2sdk1.4.2、Tomcat6.0
依赖的包:hessian-3.1.6.jar
新建一个名为HessianServer的web project。将hessian-3.2.0.jar放入WEB-INF/lib文件夹中。
创建接口
实现接口
创建User,注意实现序列化
配置web.xml
客户端代码
注意如果新建客户端工程,需引入上述jar,还需要服务端导出DemoService和User两个类的jar,放入lib。或创建两个一摸一样的类。
tomcat启动服务端,运行客户端,结果如下
hello:test
ming
m123
场景2:服务端 客户端都使用spring(在上述基础上)
依赖的包:
1. Hessian包:hessian-3.1.6.jar
2. spring-framework-2.0.2包:
a) aopalliance.jar
b) commons-logging.jar
c) log4j-1.2.14.jar
d) spring.jar
e) spring-aop.jar
f) spring-beans.jar
g) spring-context.jar
h) spring-core.jar
i) spring-jdbc.jar
j) spring-jms.jar
k) spring-web.jar
l) spring-webmvc.jar
配置web.xml,web.xml中增加:
1) 如果客户端不使用spring,客户端代码如下
2) 如果客户端使用spring,需要导入上述jar,在客户端工程src目录下,新建一个remote-hessian.xml,这个文件可随意命名,内容为:
客户端代码
在进行基于Hessian的项目开发时,应当注意以下几点:
▲JAVA服务器端必须具备以下几点:
·包含Hessian的jar包。
·设计一个接口,用来给客户端调用。
·实现该接口的功能。
·配置web.xml,配好相应的servlet。
·对象必须实现Serializable 接口。
·对于复杂对像可以使用Map的方法传递。
▲客户端必须具备以下几点:
·java客户端包含Hessian.jar的包。
·具有和服务器端结构一样的接口。
·利用HessianProxyFactory调用远程接口。
下面是一个hessian的简单例子
场景1:服务端 客户端都不使用spring
Java服务器端:
环境:j2sdk1.4.2、Tomcat6.0
依赖的包:hessian-3.1.6.jar
新建一个名为HessianServer的web project。将hessian-3.2.0.jar放入WEB-INF/lib文件夹中。
创建接口
package com.mooing.hessian; public interface DemoApi { public void setName(String name); public String sayHello(); public User getUser(); }
实现接口
package com.mooing.hessian; public class DemoService implements DemoApi{ private String name; @Override public void setName(String name) { this.name=name; } @Override public String sayHello() { System.out.println("hello,world!"); return "hello:"+name; } @Override public User getUser() { return new User("ming","m123"); } }
创建User,注意实现序列化
package com.mooing.hessian; import java.io.Serializable; public class User implements Serializable { private static final long serialVersionUID = 1L; private String name = "kitty"; private String psw = "nopww"; public User() { } public User(String name, String psw) { super(); this.name = name; this.psw = psw; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPsw() { return psw; } public void setPsw(String psw) { this.psw = psw; } }
配置web.xml
<servlet> <servlet-name>hessian</servlet-name> <servlet-class>com.caucho.hessian.server.HessianServlet</servlet-class> <init-param> <param-name>service-class</param-name> <param-value>com.mooing.hessian.DemoService</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>hessian</servlet-name> <url-pattern>/helloworld</url-pattern> </servlet-mapping>
客户端代码
注意如果新建客户端工程,需引入上述jar,还需要服务端导出DemoService和User两个类的jar,放入lib。或创建两个一摸一样的类。
package com.mooing.hessian; import java.net.MalformedURLException; import com.caucho.hessian.client.HessianProxyFactory; public class HessianClient { public static void main(String[] args) throws MalformedURLException, ClassNotFoundException { String url = "http://localhost:8080/jms1/helloworld"; HessianProxyFactory pf = new HessianProxyFactory(); DemoApi da = (DemoApi) pf.create(url); da.setName("test"); System.out.println(da.sayHello()); System.out.println(da.getUser()); } }
tomcat启动服务端,运行客户端,结果如下
hello:test
ming
m123
场景2:服务端 客户端都使用spring(在上述基础上)
依赖的包:
1. Hessian包:hessian-3.1.6.jar
2. spring-framework-2.0.2包:
a) aopalliance.jar
b) commons-logging.jar
c) log4j-1.2.14.jar
d) spring.jar
e) spring-aop.jar
f) spring-beans.jar
g) spring-context.jar
h) spring-core.jar
i) spring-jdbc.jar
j) spring-jms.jar
k) spring-web.jar
l) spring-webmvc.jar
配置web.xml,web.xml中增加:
<servlet> <servlet-name>remote</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>namespace</param-name> <param-value>classes/remote-servlet</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>remote</servlet-name> <url-pattern>/remote/*</url-pattern> </servlet-mapping> 以下是remote-servlet.xml的内容: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd"> <!-- 注入内部实现接口 --> <bean id="demoService" class="com.mooing.hessian.DemoService" /> <!-- 注入hessian发布接口 name为调用名称--> <bean name="/helloDemo" class="org.springframework.remoting.caucho.HessianServiceExporter"> <!-- 关联接口实现 --> <property name="service" ref="demoService" /> <!-- 关联接口 --> <property name="serviceInterface" value="com.mooing.hessian.DemoApi" /> </bean> </beans>
1) 如果客户端不使用spring,客户端代码如下
import java.net.MalformedURLException; import com.caucho.hessian.client.HessianProxyFactory; import com.mooing.hessian.DemoApi; public class ClientSpring { public static void main(String[] args) throws MalformedURLException, ClassNotFoundException { String url = "http://localhost:8080/jms1/remote/helloDemo"; HessianProxyFactory pf = new HessianProxyFactory(); DemoApi da = (DemoApi) pf.create(url); da.setName("test"); System.out.println(da.sayHello()); System.out.println(da.getUser()); } }
2) 如果客户端使用spring,需要导入上述jar,在客户端工程src目录下,新建一个remote-hessian.xml,这个文件可随意命名,内容为:
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <beans> <bean id="helloDemo" class="org.springframework.remoting.caucho.HessianProxyFactoryBean"> <property name="serviceUrl"> <value> http://localhost:8080/jms1/remote/helloDemo </value> </property> <property name="serviceInterface"> <value>com.mooing.hessian.DemoApi</value> </property> </bean> </beans>
客户端代码
import java.net.MalformedURLException; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.caucho.hessian.client.HessianProxyFactory; import com.mooing.hessian.DemoApi; public class ClientSpring { public static void main(String[] args) throws MalformedURLException, ClassNotFoundException { // String url = "http://localhost:8080/jms1/remote/helloDemo"; // HessianProxyFactory pf = new HessianProxyFactory(); // DemoApi da = (DemoApi) pf.create(url); // da.setName("test"); // System.out.println(da.sayHello()); // System.out.println(da.getUser()); ApplicationContext context = new ClassPathXmlApplicationContext("remote-hessian.xml"); DemoApi da = (DemoApi) context.getBean("helloDemo"); da.setName("test spring"); System.out.println(da.sayHello()); System.out.println(da.getUser()); } }
- hessian-3.2.0.jar.zip (251.7 KB)
- 下载次数: 11
发表评论
-
postgres java
2013-04-21 22:51 772postgres sql jdbc doc -
jdbctempleate 执行postgres 数据库存储过程返回结果集
2012-12-05 01:57 3109创建表: create table myuser ... -
spring mvc 支持web应用程序的文件上传功能
2012-03-24 02:30 1685spring mvc 支持web应用程序的文件上传功能,是由s ... -
servlet下载 csv 文件,中文不乱码
2012-03-24 01:47 0String helloStr ... -
extjs 的grid jsp 练习
2012-03-20 00:10 1409grid.jsp <%@ page language= ... -
java的单例模式的一个例子
2011-01-06 21:53 1693单例模式就是运行环境中只存在一个实例, java.lang.O ... -
有状态SessionBean 和无状态Sessionbean
2009-11-02 10:21 1749JavaEE中的有状态会话bean和无状态会话bean 的主要 ... -
GlassFish v2 NetBean6.5 开发ejb3.0 会话Bean
2009-11-02 09:38 2051第一个当然是永恒不变的hello world 啦。 Net ...
相关推荐
Hessian是一个轻量级的remoting on http工具,使用简单的方法提供了RMI(Remote Method Invocation,远程方法调用)的功能。采用的是二进制RPC(Remote Procedure Call Protocol,远程过程调用协议)协议,因为采用...
Spring支持多种远程调用协议,如RMI(Remote Method Invocation)、Hessian、 Burlap以及HTTP Invoker等。这些协议允许我们跨越网络边界,像调用本地方法一样调用远程服务。 在本实例中,我们关注的是HTTP Invoker...
在Spring框架中集成Hessian是为了实现远程方法调用(Remote Method Invocation, RMI),这是一种轻量级的序列化协议,可以高效地传输Java对象。Hessian使得服务提供者和服务消费者之间能够通过网络进行快速的数据...
1. RMI(Remote Method Invocation):RMI是Java平台上的标准远程调用协议,Spring Remoting对RMI的支持非常全面。开发者可以通过实现Remote接口,创建远程服务,并通过RmiRegistry注册服务,客户端则通过...
在IT行业中,远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一种用于在分布式环境中实现对象间通信的技术。Spring框架作为Java企业级应用的基石,它提供了与RMI集成的能力,使得开发者可以方便...
RMI(Remote Method Invocation,远程方法调用)是Java平台上的一个标准机制,用于在不同的Java虚拟机之间进行对象方法的调用。将Spring与RMI结合使用,可以实现分布式服务的灵活构建。 首先,我们需要理解RMI的...
* Hessian:一个轻量级的 remoting on http 工具,使用简单的方法提供了 RMI 的功能。 相比WebService,Hessian 更简单、快捷。采用的是二进制 RPC 协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。 ...
Hessian是一种二进制的Remoting协议,它旨在提供高效的远程方法调用(Remote Method Invocation,RMI)能力,通常用于分布式系统中的服务通信。 【描述】:虽然描述部分为空,但根据提供的博文链接——,我们可以...
在Java项目中,Spring RMI(Remote Method Invocation)是一种整合远程方法调用功能与Spring框架的方式,它使得在分布式环境中管理对象和服务变得更加便捷。本文将深入探讨Spring RMI涉及的包,以及如何在项目中使用...
Spring整合RMI(Remote Method Invocation)是将Spring框架与Java RMI技术相结合,实现远程服务调用的一种方式。RMI允许在分布式环境中调用对象的方法,就像调用本地对象一样,极大地增强了应用的可扩展性和灵活性。...
在Java编程领域,远程方法调用(Remote Method Invocation,简称RMI)是一项核心技术,它允许Java对象在不同的Java虚拟机之间进行通信。"simple-parent"项目似乎专注于探索和比较不同Java Remoting技术的实现及其优...
在Spring中,我们可以使用多种技术来实现Remoting,如RMI(Remote Method Invocation)、HTTP Invokers、Hessian和 Burlap等。 **注解驱动的服务暴露** 1. **@Service**: 这个注解通常用于标记业务层(Service ...
Spring RMI(Remote Method Invocation)实例是一个用于演示如何在Spring框架中使用RMI技术的简单应用。RMI是Java提供的一种远程方法调用机制,它允许一个Java对象调用位于另一台计算机上的对象的方法,实现了分布式...
Spring Remote Method Invocation (RMI) 是Spring框架提供的一种远程服务调用机制,它允许你在分布式环境中调用对象的方法,就像是在本地执行一样。这个技术基于Java的RMI系统,但通过Spring的抽象层,简化了配置和...
RMI允许一个对象调用远程机器上的对象方法,仿佛它们是在同一个进程中执行一样。通过RMI,开发者可以构建跨网络的、分布式的对象模型,使得程序可以在不同的Java虚拟机之间进行通信。 接下来,EJB(Enterprise ...
Java RMI是Java提供的一种远程方法调用机制,它允许一个对象调用另一个在网络中不同机器上的对象的方法。通过RMI,开发者可以创建跨网络的分布式对象,使得代码能够透明地操作远程对象,简化了分布式系统的设计。 ...
1. RMI(Remote Method Invocation):Java的远程方法调用机制,允许一个Java对象调用位于不同JVM上的另一个对象的方法,是Java分布式计算的基础。 2. EJB(Enterprise JavaBeans):面向企业级应用的组件模型,提供...
Spring框架提供了多种分布式解决方案,如Spring Remoting(支持RMI、Hessian、 Burlap等协议)、Spring Integration(提供企业集成模式)以及Spring Cloud(为微服务架构提供工具集,包括服务发现、配置管理、断路器...
Dubbo是一个由阿里巴巴开源的高性能、分布式的RPC(远程调用协议)服务框架。它旨在简化服务之间的通信,提供服务的自动注册、自动发现等功能,从而实现服务治理。Dubbo能够与Spring框架无缝集成,使得开发者可以像...
Dubbo是一款高性能、轻量级的开源Java RPC框架,由阿里巴巴公司开发并贡献给社区。它致力于提供一套完整的服务治理解决方案,包括服务注册、服务发现、负载均衡、容错机制等。在本文中,我们将深入探讨`dubbo-2.5.6`...