- 浏览: 209661 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
maxrocray:
现在没管用的了。。。
google的IP地址列表 -
greenwen:
谢谢您的分析,学习受教了
几种通讯协议的比较 -
chaiying:
...
几种通讯协议的比较 -
liyan12167:
哥们 我想向您请教些更详细的内容 不知道你还会在上线不 上来 ...
什么是SyncML -
追求幸福:
...
SyncML相关资源链接
<!-- Hessian服务的接口-->
<property name="serviceInterface" value="com.demo.api.server.DemoService" />
</bean>
在该配置下,Hessian服务的url是
http://IP:port/**/remote/HessianService,其中**是该应用的url。Spring使用DispatcherServlet拦截到匹配/remoting/*的请求,然后将该请求转发到对应的bean,该bean在dispatcher-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
发表评论
-
session 处理2种方式
2010-01-21 17:25 1454随着互联网的日益壮大,网站的pv和uv成线性或者指数倍的增加. ... -
异质数据结构
2009-11-21 12:28 1508堆栈、队列、链表等数据结构中的数据通常都是单一类型 ... -
Java获取代理客户端真实IP地址
2009-09-11 18:06 1954在JSP里,获取客户端的IP地址的方法是:request.ge ... -
杂论架构
2009-09-07 09:16 1105一、架构的含义 许多人对什么是架构或者架构设计包含什么内容比 ... -
nginx后面的jboss获取不到真实IP解决方案
2009-07-24 11:01 4247nginx+(1…n)tomcat集群部署时,后端tomcat ... -
byte short int long float double
2009-07-22 17:58 1556byte: 八位整数 -128——127,可用来节省内存的使用 ... -
架构思想
2009-06-26 10:15 1071一 架构思想 1.1 HTML页 ... -
jboss 4.22 优化心得
2009-01-16 13:39 1220增大可使用内存,修改bin/run.sh文件 JAVA_OPT ... -
JBoss 5.0 安装配置负载均衡
2009-01-14 17:39 5985简明JBOSS 5的安装配置说明 环境为Linux AS ... -
基于Hessian的高性能远程对象调用的服务器端和客户端的Demo
2008-12-31 10:48 2795概要介绍 在我们的项目中,特别是在J2EE分布式系统中,我们经 ... -
剔除List中的重复值
2008-08-28 22:34 1980方法一:循环元素删除 // 删除ArrayList中重复 ... -
spring 2.5 mvc annotation使用
2008-06-11 11:16 2748项目中一种在用spring2.0,虽然2.5出来了很多新特性, ... -
webwork2中文参考手册.pdf
2008-05-11 22:54 1900webwork2中文参考手册.pdf -
Spring-MVC-step-by-step2.rar
2008-05-11 22:51 952Spring-MVC-step-by-step2.pdf -
学习Spring
2008-05-08 11:58 12951、如何学习Spring? ... -
基于Spring技术应用的远程服务
2008-05-08 11:04 982来源:赛迪网 一.引言 从根本上分析,Remoting实 ... -
几种通讯协议的比较
2008-05-08 10:54 8253一、综述 本文比较了RMI,Hessian,Burlap,Ht ... -
webwork之HelloWorld篇
2008-04-29 15:20 1384任何结果都是由简单的实践得出的,当然我下面的介绍也是模仿那些大 ... -
JDK1.5中的线程池使用简介
2008-04-25 17:49 2841学习 JDK1.5中的线程池使用简介 ... -
jboss 启动时java.sql.SQLException: User not found: SA
2008-04-03 17:11 2534修改下面的文件: jboss-4.0.3\server\def ...
相关推荐
这涉及到客户端发送一个包含方法名和参数的序列化请求,服务器端接收到请求后解序列化,执行相应的方法,并将结果反序列化回客户端。 现在,让我们深入到这个"简单demo"的细节。在这个例子中,我们可能会看到以下...
- 在客户端,也需要创建与服务器端相同的接口及User类,并通过HessianProxyFactory来创建远程代理对象。 ```java HessianProxyFactory factory = new HessianProxyFactory(); DemoApi demoApi = (DemoApi) ...
Hessian是由Caucho Technology开发的一种轻量级的远程过程调用(RPC)协议,它主要设计用于Web服务。与传统的基于XML的SOAP协议相比,Hessian更加高效,因为它是二进制格式,数据传输量小,解析速度快。这使得...
然后,Hessian作为CXF和客户端之间的通信协议,提供高效的远程调用。这种组合特别适用于内部网络环境,因为它减少了数据传输的开销,提高了服务调用的响应速度。 在实际应用中,我们可能需要以下步骤来实现“CXF+...
2. 服务器端接收请求:服务器接收到请求后,通过`HttpInvokerServiceExporter`解析请求,找到对应的服务实现,并调用相应的方法。 3. 数据传输:请求和响应的数据都通过HTTP协议进行传输,Spring会自动处理对象的...
在IT行业中,Dubbo是一款非常著名的高性能、轻量级的Java RPC框架,它由阿里巴巴开源并在社区中得到了广泛的应用和持续的发展。这个“dubbo 使用基本功能demo”项目旨在通过一个简单的实例,帮助开发者理解并掌握...
【标题】"Dubbo案例Demo代码"涉及到的核心技术是Dubbo,它是一个高性能、轻量级的开源Java RPC框架,由阿里巴巴开发并贡献给Apache基金会。Dubbo的主要目的是解决分布式系统中的服务调用问题,提高服务的可扩展性和...
在IT行业中,分布式系统是大型应用...总结来说,Zookeeper和RPC在Java分布式开发中扮演了重要角色,理解并掌握这两者有助于构建高可用、高性能的分布式系统。通过学习和实践,你可以进一步提升在分布式领域的技术水平。
1. **服务接口定义**: 应该包含服务提供者和消费者共同遵循的服务接口,这些接口定义了可以被远程调用的方法。 2. **服务暴露**: 实现服务提供者将服务注册到注册中心的逻辑,这通常涉及到服务的元数据(如接口名、...