java中可用的远程技术包括RMI、Caucho的Hessian和Burlap|、Spring的HTTP invoker、SOAP和JAX-RPC的web service。
spring简化RMI.
客户端
只需在spring配置文件中声明下面的<bean>
<bean id="testService" class="org.springframework.remoting.rmi.RmiProxyFactoryBean">
<property name="serviceUrl" value="rmi://127.0.0.1:1099/testService"></property>
<property name="serviceInterface" value="com.pm.service.TestService"></property>
</bean>
然后在需要的地方,就可以使用这个远程对象了,如:
<bean id="employeeService" class="com.pm.service.imp.EmployeeServiceImp">
<property name="employeeDao" ref="employeeDao"></property>
<property name="testService" ref="testService"></property>
</bean>
服务端,输出一个RMI:
1.创建一个普通服务接口,
package com.test;
public interface TestService {
public void print(String name);
}
2.创建一个接口实现类:
package com.test;
public class TestServiceImp implements TestService{
public void print(String name) {
System.out.println(name+"你好啊!哈哈");
}
}
3.在spring配置文件中配置 TestServiceImp bean:
<bean id="testService" class="com.test.TestServiceImp"></bean>
4.使用RmiServiceExporter将testService公开为RMI服务:
<bean class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="service" ref="testService"></property>
<property name="serviceName" value="testService"></property>
<property name="serviceInterface" value="com.test.TestService"></property>
<property name="registryPort" value="1099"></property>
</bean>
其中registryPort默认就是1099。
至此,一个RMI客户端调用与服务端输出大功告成。但RMI可以使用任意端口,这是防火墙不允许的,还有,RMI是基于java的,这就意味着客户端和服务端都必须用java编写,为了解决这些限制,于是乎,引出了下面这些技术。
spring简化Hessian和Burlap
Hessian和Burlap是基于HTTP的轻量级远程服务,两者其实差不多,Hessian是基于二进制消息来建立客户端与服务端 之间的交流,而Burlap是基于XML的。
首先无论客户端还是服务器端,都得导入hessian.jar
还是以上面的例子,如果是客户端,我们只要修改一下spring配置文件的一个bean即可
Hessian:
<bean id="hessianTestService" class="org.springframework.remoting.caucho.HessianProxyFactoryBean">
<property name="serviceUrl" value="http://127.0.0.1:8080/SpringRmi/test.service"></property>
<property name="serviceInterface" value="com.pm.service.TestService"></property>
</bean>
Burlap:
<bean id="hessianTestService" class="org.springframework.remoting.caucho.BurlapProxyFactoryBean">
<property name="serviceUrl" value="http://127.0.0.1:8080/SpringRmi/test.service"></property>
<property name="serviceInterface" value="com.pm.service.TestService"></property>
</bean>
而如果要配置服务端,则比RMI要稍微复杂点点:
1.在spring配置文件中:
<!--配置一个SimpleUrlHandlerMapping:-->
<bean id="urlMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="/test.service">hessianServiceExporter</prop>
</props>
</property>
</bean>
<bean id="hessianServiceExporter" class="org.springframework.remoting.caucho.HessianServiceExporter">
<property name="service" ref="testService"></property>
<property name="serviceInterface" value="com.test.TestService"></property>
</bean>
<!-- 或者 -->
<bean id="burlapServiceExporter" class="org.springframework.remoting.caucho.BurlapServiceExporter">
<property name="service" ref="testService"></property>
<property name="serviceInterface" value="com.test.TestService"></property>
</bean>
2.在web.xml中:
<servlet>
<servlet-name>test</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:applicationContext.xml
</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>test</servlet-name>
<url-pattern>*.service</url-pattern>
</servlet-mapping>
在测试过程中遇到,在启动客户端容器时会报:
org.springframework.web.HttpRequestMethodNotSupportedException: HessianServiceExporter only supports POST requests
找了好久,不知道是什么原因造成的,但似乎不影响程序运行。
HTTP invoker是基于Spirng的,用法跟Hessian、Burlap差不多,只需把org.springframework.remoting.caucho.HessianProxyFactoryBean与org.springframework.remoting.caucho.HessianServiceExporter替换成org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean与org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter
分享到:
相关推荐
首先,我们要明确Spring远程调用(Remoting)的基本概念。远程调用是指应用程序的不同组件或服务之间,通过网络进行通信的一种方式。Spring支持多种远程调用协议,如RMI(Remote Method Invocation)、Hessian、 ...
首先,我们需要理解什么是Spring远程调用。Spring Remote提供了一种机制,使得应用程序能够跨越网络边界调用其他服务的方法,仿佛它们是在同一进程中执行一样。HTTP远程调用是Spring Remote的一种实现方式,通过HTTP...
因为上传大小的限制,分为两部分上传,这是第二部分,... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
5. **客户端调用**:最后,客户端可以像调用本地对象一样调用远程服务。我们只需要获取HttpInvokerProxyFactoryBean创建的代理对象,然后直接调用接口方法即可。 ```java @Autowired private UserService ...
在Java EE平台上,Spring框架提供了一种强大的方式来实现远程服务调用,特别是通过其HttpInvokerServiceExporter组件来实现基于HTTP的WebService功能。这个技术允许客户端和服务端通过HTTP协议进行通信,实现远程...
因为上传大小的限制,分为两部分上传,这是第一部分,... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
- **Spring远程服务**:Spring框架支持多种远程服务调用机制,如RMI、HTTP invoker等,简化了远程服务的开发和部署。 5. **Web层支持** - **Spring MVC**:Spring框架提供了一种模型-视图-控制器(Model-View-...
Spring专家力作 理论与实践完美结合 问题描述→解决方案... 第16章 Spring远程服务和Web服务 第17章 Spring对EJB和JMS的支持 第18章 Spring对JMX、电子邮件和调度的支持 第19章 Spring中的脚本编程
标题中的"Spring 远程调用"指的是Spring的远程服务访问(Remote Service Access,RSA)。RSA允许服务提供者创建远程服务,而服务消费者可以跨网络调用这些服务。在Web服务上下文中,Spring提供了WebServiceTemplate...
Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来调用远程服务。在本文中,我们将介绍如何使用 Spring Cloud Feign 实现远程调用服务传输文件的方法。 Feign 介绍 ...
Spring远程访问通过使用普通POJOs,能更容易的开发远程访问服务。目前,Spring远程访问的主要技术如下: 1. 远程调用RMI(Remote Method Invocation): 通过使用 RmiProxyFactoryBean 和 RmiServiceExporter,并且,...
本篇文章将深入探讨如何将Spring与Hessian整合,以便在分布式系统中轻松实现远程服务调用。 首先,让我们理解Spring整合Hessian的基本原理。Spring通过其强大的IoC(Inversion of Control)容器管理服务和客户端,...
上文我们利用Spring rmi实现了Spring的远程访问(Spring 实现远程访问详解——rmi),本文主要讲解利用HttpInvoke实现远程访问。 Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和...
在Spring中,RMI的实现被集成到IoC(Inversion of Control)容器中,这样可以方便地管理和配置远程服务。 服务端的实现通常包括以下步骤: 1. **定义远程接口**:这是服务端提供给客户端调用的接口,需要使用`@...
"Spring Boot 使用 FTP 方式上传文件到远程服务器" 在本文中,我们将详细介绍如何使用 Spring Boot 框架来实现 FTP 方式上传文件到远程服务器。FTP(File Transfer Protocol)是一种常用的文件传输协议,广泛应用于...
使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528
标题 "spring远程调用和xfire aegis 源代码上传" 涉及到的是在Java开发中使用Spring框架进行远程过程调用(RPC)以及整合XFire和Aegis库来实现服务间的通信。这一主题是分布式系统设计中的一个重要组成部分,特别是...
本项目为spring-boot+webSocket实现的向日葵远程控制项目 向日葵是一款很好用的远程操作软件。 一直很好奇这种软件的基本原理是如何的? 今天带大家通过一个简单的项目来探究一下,并实现一个简单的远程操控软件 ...
首先,理解Spring远程服务调用的核心概念。Spring Remoting是Spring框架的一部分,它提供了一种透明的方式来调用远程服务,仿佛它们是本地对象一样。这包括了RMI、Hessian、 Burlap以及HTTP-based协议如Web Services...