`
yanlp
  • 浏览: 76700 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Spring远程服务

阅读更多

       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远程调用简单实例

    首先,我们要明确Spring远程调用(Remoting)的基本概念。远程调用是指应用程序的不同组件或服务之间,通过网络进行通信的一种方式。Spring支持多种远程调用协议,如RMI(Remote Method Invocation)、Hessian、 ...

    Spring远程调用使用http方式

    首先,我们需要理解什么是Spring远程调用。Spring Remote提供了一种机制,使得应用程序能够跨越网络边界调用其他服务的方法,仿佛它们是在同一进程中执行一样。HTTP远程调用是Spring Remote的一种实现方式,通过HTTP...

    Spring攻略PDF版

    因为上传大小的限制,分为两部分上传,这是第二部分,... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    spring远程调用

    5. **客户端调用**:最后,客户端可以像调用本地对象一样调用远程服务。我们只需要获取HttpInvokerProxyFactoryBean创建的代理对象,然后直接调用接口方法即可。 ```java @Autowired private UserService ...

    使用spring远程调用服务端接口实现WebService功能

    在Java EE平台上,Spring框架提供了一种强大的方式来实现远程服务调用,特别是通过其HttpInvokerServiceExporter组件来实现基于HTTP的WebService功能。这个技术允许客户端和服务端通过HTTP协议进行通信,实现远程...

    Spring攻略中文版PDF

    因为上传大小的限制,分为两部分上传,这是第一部分,... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    Spring in Action 2nd Edition

    - **Spring远程服务**:Spring框架支持多种远程服务调用机制,如RMI、HTTP invoker等,简化了远程服务的开发和部署。 5. **Web层支持** - **Spring MVC**:Spring框架提供了一种模型-视图-控制器(Model-View-...

    Spring攻略英文版(附带源码)

    Spring专家力作 理论与实践完美结合 问题描述→解决方案... 第16章 Spring远程服务和Web服务   第17章 Spring对EJB和JMS的支持   第18章 Spring对JMX、电子邮件和调度的支持   第19章 Spring中的脚本编程 

    Spring 远程调用 -- C# 访问java WEB 服务

    标题中的"Spring 远程调用"指的是Spring的远程服务访问(Remote Service Access,RSA)。RSA允许服务提供者创建远程服务,而服务消费者可以跨网络调用这些服务。在Web服务上下文中,Spring提供了WebServiceTemplate...

    spring cloud feign实现远程调用服务传输文件的方法

    Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来调用远程服务。在本文中,我们将介绍如何使用 Spring Cloud Feign 实现远程调用服务传输文件的方法。 Feign 介绍 ...

    Spring 实现远程访问详解——rmi

    Spring远程访问通过使用普通POJOs,能更容易的开发远程访问服务。目前,Spring远程访问的主要技术如下: 1. 远程调用RMI(Remote Method Invocation): 通过使用 RmiProxyFactoryBean 和 RmiServiceExporter,并且,...

    Spring整合Hessian访问远程服务

    本篇文章将深入探讨如何将Spring与Hessian整合,以便在分布式系统中轻松实现远程服务调用。 首先,让我们理解Spring整合Hessian的基本原理。Spring通过其强大的IoC(Inversion of Control)容器管理服务和客户端,...

    Spring 实现远程访问详解——httpinvoker

    上文我们利用Spring rmi实现了Spring的远程访问(Spring 实现远程访问详解——rmi),本文主要讲解利用HttpInvoke实现远程访问。 Spring httpInvoker使用标准java序列化机制,通过Http暴露业务服务。如果你的参数和...

    spring RMI 远程接口调用

    在Spring中,RMI的实现被集成到IoC(Inversion of Control)容器中,这样可以方便地管理和配置远程服务。 服务端的实现通常包括以下步骤: 1. **定义远程接口**:这是服务端提供给客户端调用的接口,需要使用`@...

    springboot以FTP方式上传文件到远程服务器

    "Spring Boot 使用 FTP 方式上传文件到远程服务器" 在本文中,我们将详细介绍如何使用 Spring Boot 框架来实现 FTP 方式上传文件到远程服务器。FTP(File Transfer Protocol)是一种常用的文件传输协议,广泛应用于...

    Spring配置hessian远程服务

    使用eclipse maven工程搭建hessian远程服务demo 分服务端的整合和客户端 建议阅读相关博客http://blog.csdn.net/heisemuyangquan/article/details/79460528

    spring远程调用和xfire aegis 源代码上传

    标题 "spring远程调用和xfire aegis 源代码上传" 涉及到的是在Java开发中使用Spring框架进行远程过程调用(RPC)以及整合XFire和Aegis库来实现服务间的通信。这一主题是分布式系统设计中的一个重要组成部分,特别是...

    spring-boot+webSocket实现向日葵远程控制

    本项目为spring-boot+webSocket实现的向日葵远程控制项目 向日葵是一款很好用的远程操作软件。 一直很好奇这种软件的基本原理是如何的? 今天带大家通过一个简单的项目来探究一下,并实现一个简单的远程操控软件 ...

    spring-remote-service-example:一个示例项目,用于展示如何使用 JSON 反序列化通过 HTTP 在隔离的 Spring 容器之间进行(远程)服务调用

    首先,理解Spring远程服务调用的核心概念。Spring Remoting是Spring框架的一部分,它提供了一种透明的方式来调用远程服务,仿佛它们是本地对象一样。这包括了RMI、Hessian、 Burlap以及HTTP-based协议如Web Services...

Global site tag (gtag.js) - Google Analytics