WebService,ESB笔记

本文详细介绍了WebService的概念及其实现原理,包括其核心组成部分WSDL、UDDI和SOAP的作用,以及WebService在ESB(企业服务总线)中的应用。此外,还介绍了如何使用@WebService等注解来实现基于Java的WebService开发。
摘要由CSDN通过智能技术生成

一、WebService是什么?

WebService,是RPC的一样实现方式。

RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议

客户端要能调用服务端必须遵循TCP协议,而WebService使用的是更高一级的HTTP协议。

客户端访问服务器的目的是为了获取数据,那数据格式必须是与平台、语言无关的。WebService采用的是XML.

 

WebService的使用场景:ESB(企业服务总线)

如果一个企业存在多个使用不同语言开发的在用系统,数据传递和整合就显得尤其麻烦,利用传统连接各个系统的方法,存在如果新添加一个系统,都需要和每一个已经存在的系统建立关联,集成系统的时候入侵性太强,往往伴随着整体系统结构的改变。

所以在这种场景下,可在企业系统里搭建一根总线——ESB(企业服务总线),用来连接企业里各个系统的服务的。每个系统和总线连接起来,用XML传输数据。

把各系统连接到总线上以后,例如查询销售单,把请求抛给总线,由总线负责把消息带到进销存系统中去,再把结果按照应的规范传到总线上,由总线负责把结果返回到财务系统中。若要增加额外的系统,如WebQQ,就只需要把他挂到ESB上就OK了。ESB也是一个应用模块,负责把每个系统连接起来。

ESB全称为EnterpriseServiceBus,即企业服务总线。

它是传统中间件技术与XML、Web服务等技术结合的产物。ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素。ESB的出现改变了传统的软件架构,可以提供比传统中间件产品更为廉价的解决方案,同时它还可以消除不同应用之间的技术差异,让不同的应用服务器协调运作,实现了不同服务之间的通信与整合。从功能上看,ESB提供了事件驱动和文档导向的处理模式,以及分布式的运行管理机制,它支持基于内容的路由和过滤,具备了复杂数据的传输能力,并可以提供一系列的标准接口。

ESB不是万能的,他不是一个应用程序框架,也不是一个企业应用的解决方案.它只是一个基于消息的调用企业服务的通信模块!你可以把它嵌入到你的应用程序框架中,例如嵌入到spring容器里面,或者嵌入到工作流系统中.它的作用是对企业里面的SOA服务的调用提供一个框架和简便的方法。

 

SOA

对于这一种架构,我们称为SOA:面向服务的架构。要使用总线上挂的各个服务则需要对暴露的接口做一个描述。

第一,ESB怎么知道有哪些什么样服务?那此时我们就得对暴露出去的服务做一个描述,而这个描述就是WSDL。

WSDL(WebServicesDescriptionLanguage):WS的描述语言。告诉总线自己暴露了哪些服务。

第二,查询:我暴露了这个服务,要找到他则需要一个类似于DNS这样的东西,用于服务的注册、查询,而这个就是UDDI。

UDDI(Universal Description,Discovery andIntegration):是一种目录服务,用于统一地描述、发现和集成协议。UDDI定义如何查找WS(及其WSDL文件),可它并不像WSDL和SOAP一样深入人心,因为很多时候,使用者都知道Web服务的位置(通常位于公司的企业内部网中)。

第三,传输数据:定义数据传输规范,这里都使用XML进行传递,把对象和XML进行转换由SOAP规范。

SOAP(Simple Object Access Protocol):简单对象访问协议。是一种轻量的、简单的、基于XML的协议,它被设计成在WEB上交换结构化的和固化的信息。

 

二、关于WebService

WS是一种基于Http协议和XMl技术,并使用WSDL描述和使用SOAP协议传输的异构系统解决方案。 跨语言、跨系统

我们把调用WS的应用程序称为客户端,把提供WS的应用程序称为服务器端。

使用WS最重要的是什么:

        一是:WSDL文件(服务藐视);

        二是:对象与XML转换(数据)。

WS和SOA的区别:

Web Service是技术规范,而SOA是设计原则,一种架构模式。

WSDL,UDDI和SOAP是SOA基础的基础部件。

WSDL:用来描述服务;

UDDI:用来注册和查找服务;

SOAP:作为传输层,用来在客户端和服务器端之间传送消息。

 

三、关于WebService的常见标签

1、 @WebService标签

使用@WebService标签,需要配置在类上,代表这是一个提供WS的服务类。

endpointInterface:定义服务抽象WebService 协定的服务端点接口的完整名称。不允许在端点上使用此成员值,该元素的值必须有WebService标签。默认情况下,服务器自动生成服务端接口。

name:服务接口名称(对应wsdl: portType的name属性,用在服务接口上);

serviceName:服务类名称。默认为,实现类名+Service(对应service的name和definition上的name属性对应,用在实现类上)。

portName:Web Service的端口名称。此名称被用作wsdl:port的名称。

targetNamespace:目标命名空间,描述服务的预定义WSDL的位置(同时用在实现类和服务接口上,需统一)。

wsdlLocation:WSDL地址(服务端除了WSDL优先的情况外可不写,客户端代理接口上必须配置此属性,指向web端WSDL文件地址)

 

2 @WebMethod标签

使用@WebMethod标签,需要把他配置到方法上。

operationName:指定暴露服务方法的别名。

exclude:是否暴露此标记的方法。

 

3 @WebResult标签

使用@WebResult标签,需要把他标记在方法上或者方法返回类型定义之前。

name:定义返回值的名称。

header:布尔类型,是否把值放到header元素中进行传递。

 

4 @WebParam标签

使用@WebParam标签,需要把他标记在形参声明之前。

name:定义传递时参数的名称(默认参数以arg0,arg1…)。

header:布尔类型,是否把值放到header元素中进行传递。

 

5 @SOAPBinding

使用@ SOAPBinding标签,需要把他标记在类上。

SOAPBinding.ParameterStyleparameterStyle 确定方法参数是否表示整个消息正文,或者参数是否是包装在以操作命名的顶层元素中的元素。

SOAPBinding.ParameterStyle.WRAPPED,默认,使用对参数进行包装

SOAPBinding.ParameterStyle.BARE,不对参数进行包装

SOAPBinding.Style style 定义发 送到Web Service 的消息 和从Web Service发送的消息的编码样式。

SOAPBinding.Style.RPC:面向RPC

SOAPBinding.Style.DOCUMENT 默认,面向文档

SOAPBinding.Useuse 定义发送到WebService的消息和从WebService发送的消息的格式样式。

SOAPBinding.Use.LITERAL,默认,字面量风格,若服务端和客户端不在一起开发,就应该使用这个

SOAPBinding.Use.ENCODED使用SOAP编码风格,可能导致WS互操作方面失败问题,尽量避免使用。

转载于:https://www.cnblogs.com/applerosa/p/6001270.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值