`
dalezhu
  • 浏览: 207273 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

基于Hessian的高性能远程对象调用的服务器端和客户端的Demo 2

    博客分类:
  • Java
阅读更多

<!--  Hessian服务的接口-->

 <property name="serviceInterface" value="com.demo.api.server.DemoService" />

</bean>

在该配置下,Hessian服务的url

http://IP:port/**/remote/HessianService,其中**是该应用的urlSpring使用DispatcherServlet拦截到匹配/remoting/*的请求,然后将该请求转发到对应的bean,该beandispatcher-servlet.xml文件中以HessianServiceExporter定义。

 

二.客户端

同样我们创建工程和代码

Web project&code

public interface DemoService {

    List getUsers();

}

下面注意了:

创建可序列化对象,就是Server端的那个syncobject,而且要implements Serializable。这个也是我们要远程对象调用的domain类。

public class SyncObject implements Serializable {

    /**

     * Comment for <code>serialVersionUID</code>

     */

    private static final long serialVersionUID = 1L;

    private String username="";

    private String password="";

    public String getUsername() {

       return username;

    }

    public void setUsername(String username) {

       this.username = username;

    }

    public String getPassword() {

       return password;

    }

    public void setPassword(String password) {

       this.password = password;

    }

}

配置文件config.xml

<bean id="hessianService" class="org.springframework.remoting.caucho.HessianProxyFactoryBean">

<!--服务器端发布的地址URL-->

        <property name="serviceUrl" value="http://ip:port/**/remote/HessianService" />

<!--本地接口à

        <property name="serviceInterface" value="com.demo.api.client.DemoService"/>

</bean>

最后我们写个测试方法:

public static void main(String[] args) {

        final ApplicationContext context = new ClassPathXmlApplicationContext("config.xml");

        DemoService service = (DemoService)context.getBean("hessianService");

        try {

        List<SyncObject> userlist= service.getUsers();

         for (SyncObject user : userlist) {

              System.out.println(user.getUsername());

         }   

        }

        catch(RemoteException e) {

           e.printStackTrace();

        }

}

Run一把试试,(确保服务器端runing状态哦)

下面是成功后的信息,结果是从服务器端取到了2个用户的username

2008-12-31 10:31:15 org.springframework.core.CollectionFactory <clinit>

信息: JDK 1.4+ collections available

2008-12-31 10:31:16 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions

信息: Loading XML bean definitions from class path resource [config.xml]

2008-12-31 10:31:16 org.springframework.context.support.AbstractRefreshableApplicationContext refreshBeanFactory

信息: Bean factory for application context [org.springframework.context.support.ClassPathXmlApplicationContext;hashCode=11988197]: org.springframework.beans.factory.support.DefaultListableBeanFactory defining beans [hessianService]; root of BeanFactory hierarchy

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext refresh

信息: 1 beans defined in application context [org.springframework.context.support.ClassPathXmlApplicationContext;hashCode=11988197]

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext initMessageSource

信息: Unable to locate MessageSource with name 'messageSource': using default [org.springframework.context.support.DelegatingMessageSource@b8f82d]

2008-12-31 10:31:16 org.springframework.context.support.AbstractApplicationContext initApplicationEventMulticaster

信息: Unable to locate ApplicationEventMulticaster with name 'applicationEventMulticaster': using default [org.springframework.context.event.SimpleApplicationEventMulticaster@b1b4c3]

2008-12-31 10:31:16 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons

信息: Pre-instantiating singletons in factory [org.springframework.beans.factory.support.DefaultListableBeanFactory defining beans [hessianService]; root of BeanFactory hierarchy]

2008-12-31 10:31:16 org.springframework.aop.framework.DefaultAopProxyFactory <clinit>

信息: CGLIB2 not available: proxyTargetClass feature disabled

username1 from server

username2 from server

 

分享到:
评论

相关推荐

    hessian 服务器 客户端 demo

    综上所述,"hessian 服务器 客户端 demo"是一个演示如何使用Hessian协议实现服务器和客户端之间的RPC通信的示例。这个压缩包可能包含了服务器和客户端的代码实现,帮助开发者了解和学习如何在实际项目中应用Hessian...

    hessian demo 包括服务端和客户端

    6. **调用远程方法**:通过代理对象调用服务端的方法,就像调用本地方法一样。 **标签中的“hessian”和“java”**表明这是关于Java平台上的Hessian技术。Hessian是跨语言的,但在这个例子中,我们专注于Java环境下...

    hessian服务器和客户端

    在本项目中,我们探讨的是基于C#实现的Hessian服务端和客户端,已经在IIS环境下进行了测试并成功通过。 1. **Hessian协议**:Hessian是由Caucho公司开发的一种轻量级、高效的二进制协议,主要用于Web服务。它支持...

    Hessian远程调用RPC最简单demo

    本教程将详细介绍"Hessian远程调用RPC最简单demo",包括服务器端服务发布和客户端服务调用的实现,以及所需资源。 首先,我们来看一下`hessian-4.0.7.jar`这个文件。这是Hessian库的核心组件,包含了实现Hessian...

    java+hessian 远程调用

    - **配置详解**:文档通常会包含如何配置Hessian服务端和客户端的详细步骤,例如设置服务器端的监听端口,客户端的连接参数等。 - **示例代码**:提供服务端和服务端的代码示例,展示如何创建、注册服务以及如何...

    Hessian Binary Web Service Protocol远程接口调用入门Demo

    Hessian二进制Web服务协议(Hessian Binary Web Service Protocol)是一种高效的、轻量级的远程过程调用(RPC)协议,它主要用于提高Web服务之间的通信效率。Hessian由Caucho Technology公司开发,旨在解决XML-RPC在...

    hessian实现远程调用

    在IT行业中,远程调用是一种常见的技术,使得客户端可以跨网络调用远程服务器上的方法,就像调用本地方法一样方便。Hessian是Apache项目下的一个轻量级的RPC(Remote Procedure Call,远程过程调用)框架,它提供了...

    使用hessian进行服务器-客户端通讯

    5. **调用服务**:一旦连接建立,客户端就可以像调用本地对象一样调用远程服务的方法,Hessian会自动处理网络传输和数据类型转换。 6. **处理响应**:服务器端执行完方法后,将结果返回给客户端,Hessian会将结果反...

    Hessian学习简单demo

    这涉及到客户端发送一个包含方法名和参数的序列化请求,服务器端接收到请求后解序列化,执行相应的方法,并将结果反序列化回客户端。 现在,让我们深入到这个"简单demo"的细节。在这个例子中,我们可能会看到以下...

    Hessian远程调用框架学习一

    Hessian远程调用框架是基于Java的轻量级RPC(Remote Procedure Call)解决方案,它允许开发者在分布式系统中实现高效、便捷的跨网络对象方法调用。本教程将引导你入门Hessian,通过一个简单的JAVA demo来理解其工作...

    hessian php与java通讯demo源码

    Hessian库会自动处理序列化和反序列化,使得客户端可以像调用本地方法一样调用远程服务。 3. **PHP客户端** (`php-client.rar`): - PHP客户端同样利用Hessian协议来调用Java服务器上的服务。 - PHP中,你可以...

    hessian框架应用,实现远程调用,分布式开发

    2. 使用工厂生成服务接口的代理对象,这个对象可以像调用本地方法一样调用远程服务。 3. 执行远程调用,结果会自动反序列化为Java对象。 四、Hessian与其他远程调用框架的比较: 1. **RMI**:Java原生的RMI使用...

    hessian-demo示例

    - 客户端代码可以通过Spring的依赖注入获取服务代理,然后像调用本地方法一样调用远程服务。 3. **运行与测试:** - 启动Jetty服务器,加载Spring上下文,启动Hessian服务。 - 客户端通过HTTP调用Hessian服务,...

    spring整合hessian进行远程通讯

    Spring会自动创建代理对象,使得客户端可以通过这个代理对象调用远程服务的方法,就像调用本地对象一样。 3. **使用源码分析**: Hessian库提供了`HessianProxyFactoryBean`和`HessianServiceExporter`这两个关键...

    hessian通讯的安卓实现的简单DEMO

    开发者通常会使用Hessian库来实现客户端和服务端之间的通信,使得Android应用可以调用远程服务端的方法,就像调用本地方法一样方便。 3. **Hessian库的集成**:在Android项目中,需要引入支持Android的Hessian库,...

    基于WebService的Hessian例子教程

    【描述】提供的教程包含了服务器端和客户端的实例代码,这两个例子旨在帮助开发者快速理解和应用Hessian。它们非常直观,可以直接运行,无需复杂配置,从而让你对Hessian的工作原理有深刻的理解。 首先,我们来了解...

    hessian服务端 客户端 可运行

    通过这个示例,你可以深入理解如何在Java环境中搭建和使用Hessian服务,以及如何在客户端进行远程调用,这对于理解和应用RPC技术是非常有价值的。同时,这也展示了Hessian在实现高效、轻量级的分布式系统中的潜力。

    Hprose 全名是高性能远程对象服务引擎.rar

    1. 什么是 rpc RPC 全称为 Remote Procedure Call,翻译过来为 “远程过程调用”。 目前,主流的平台中都支持各种远程调用技术,以满足...RPC 在使用形式上像调用本地函数(或方法)一样去调用远程的函数(或方法)。

    轻量级远程服务调用Hessian的入门实例和与Spring整合的实例.zip

    在服务器端,通过HessianServlet来暴露这个服务,客户端则通过HessianProxyFactory来创建服务代理,从而能够调用远程服务的方法。这种简单设置可以让开发者快速理解Hessian的基本工作原理。 二、Hessian与Spring...

Global site tag (gtag.js) - Google Analytics