wsdl文档结构

本文转自:http://blog.csdn.net/changyuming/article/details/3042601
   

     WSDL把service定义为网络端点(或port)集合。在WSDL中,端点和消息的抽象定义与具体的网络部署或数据格式分开定义。这允许对抽象定义的重用。

     WSDL中主要包含以下6个元素:
     (1)definitions:是WSDL文档的根源素,主要用来定义web服务的名称、声明一些命名空间并包含下面的几个元素。
     (2)types:包含一些WSDL文档中使用的数据类型定义。如果WSDL文档中只使用xml架构内建的简单类型,则可以省略types元素。
     (3)message:是对被交换数据的抽象描述。它描述了一个单向的消息,即它要么是一个单一的请求消息,要么是一个单一的响应消息。message元素定义了消息的名称并包含0个或多个part元素,它们表示消息的参数或消息的返回值。
     (4)portType:表示端点支持的一组抽象操作。可以把多个message元素结合在一起来构成一个完整的单向或双向操作。
     (5)binding:为一个特定的端口类型指定了具体的协议和数据格式。
     (6)service:是一组相关端口(使用port元素表示)的集合,其中,每一个端口都表示一个端点,包含具体的绑定和网络地址。
     除了以上的6个主要元素之外,WSDL文档中还可以包含documentation元素(用来添加注释)和import元素(用来导入外部文档)。其中在documentation元素中可以包含肉眼可以读的注释信息,这个元素可以出项在任何的WSDL元素中。

1、definitions元素
是WSDL文档的根源素,用药声明一些命名空间。
下面是常用的命名空间:
前缀 命名空间URI 描述
http http://schemas.xmlsoap.org/wsdl/http WSDL HTTP GET POST绑定的命名空
soap http://schemas.xmlsoap.org/wsdl/soap WSDL SOAP绑定的命名空间
xsd http://www.w3.org/2001/XMLSchema/ XSD定义的架构命名空间
soapenc http://schemas.xmlsoap.org/soap/encoding SOAP1.1定义的编码命名空间
mime http://schemas.xmlsoap.org/wsdl/mime/ WSDL MIME绑定的命名空间
wsdl http://schemas.xmlsoap.org/wsdl/ WSDL架构的命名空间
        在 definitions元素中也可以使用targetNamespace属性指定当前WSDL文档的目标命名空间,并可以为它指定一个前缀,这样就可以在 当前WSDL文档中通过它来引用自身。例如,下面的两条声明把http://www.mycompany.com/service指定为当前WSDL文档 的目标命名空间,并可以在文档中使用s0前缀来引用它:
xmlns:s0="http://www.mycompany.com/service"
targetNamespace="http://www.mycompany.com/service"
     可以使用definitions元素的name属性为WSDL文档指定一个可选名称。
     另外,还可以在definitions元素中使用import元素导入外部的文档,并给它指定一个命名空间,形式为:

  导入外部文档之后,就可以在当前文档中引用外部文档中的类型和元素。
     通过使用import元素,用户可以根据抽象级别把不同的元素定义放在不同的文档中,然后再根据需要导入它们。

2、type元素
包含一些与消息相关额数据类型定义。wsdl通常使用xsd作为它的内建类型系统以达到最大的互操作性 和平台无关性。因为不可能使用一个单一的类型系统语法来描述所有的抽象类型,所以wsdl允许通过扩充性元素来增加类型系统。扩充性元素可以出项在 types元素下,指定一个类型定义系统并包含这些类型定义。

3、message元素
表 示消息的抽象定义。消息由一个或多个逻辑部分(使用part元素表示)组成,每个部分都可以使用element属性或type属性关联到一个类型上,其中 element属性使用限定名引用一个xsd元素;type属性使用限定名引用一个xsd simpleType或complexType。
格式如下:



......

 
其中,消息的名称应该能够在当前wsdl文档中唯一标识一个消息,部分名应该能够在当前消息中唯一地标识一个部分。如果一个消息具有多个逻辑单元,则用户可 以在message元素中包含多个part子元素;也可以先定义一个表示消息逻辑结构的复杂类型,然后再message元素中仅包含一个引用该类型的 part子元素。
例如,下面定义的AddHttpGetin消息中包含2个part元素:





 
下面定义的AddSoapin消息中,则只包含一个引用复杂类型的part子元素Add:













 
4、portType元素
表 示端口类型的抽象定义,端口类型由一种抽象操作组成。在定义portType元素时,使用name属性指定它的名字。portType元素中可以包含0个 或多个operation子元素,operation元素又可以包含对应于操作参数和返回结果的输入和输出消息,分别使用input和output元素表 示,在这2个元素中可以使用message属性指定它们所对应的消息。例如:



返回字符串HelloWorld




返回两个整数的和




 
5、binding元素
定义了portType元素中的operation和message元素的消息格式和协议细节。一个给定的portType可以具有任意数目的绑定。格式如下:











 





你可能感兴趣的:([转帖],[转帖分析])