c# Web Services学习笔记(七、WSDL文档的结构)

    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描述
httphttp://schemas.xmlsoap.org/wsdl/httpWSDL HTTP GET POST绑定的命名空
soaphttp://schemas.xmlsoap.org/wsdl/soapWSDL SOAP绑定的命名空间
xsdhttp://www.w3.org/2001/XMLSchema/XSD定义的架构命名空间
soapenchttp://schemas.xmlsoap.org/soap/encodingSOAP1.1定义的编码命名空间
mimehttp://schemas.xmlsoap.org/wsdl/mime/WSDL MIME绑定的命名空间
wsdlhttp://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 namespace="uri" location="uri">
    导入外部文档之后,就可以在当前文档中引用外部文档中的类型和元素。
    通过使用import元素,用户可以根据抽象级别把不同的元素定义放在不同的文档中,然后再根据需要导入它们。
2、type元素
包含一些与消息相关额数据类型定义。wsdl通常使用xsd作为它的内建类型系统以达到最大的互操作性和平台无关性。因为不可能使用一个单一的类型系统语法来描述所有的抽象类型,所以wsdl允许通过扩充性元素来增加类型系统。扩充性元素可以出项在types元素下,指定一个类型定义系统并包含这些类型定义。
3、message元素
表示消息的抽象定义。消息由一个或多个逻辑部分(使用part元素表示)组成,每个部分都可以使用element属性或type属性关联到一个类型上,其中element属性使用限定名引用一个xsd元素;type属性使用限定名引用一个xsd simpleType或complexType。
格式如下:
<message name="消息名">
<part name="部分名" element="name"(或type="qname")/>
......
</message>
其中,消息的名称应该能够在当前wsdl文档中唯一标识一个消息,部分名应该能够在当前消息中唯一地标识一个部分。如果一个消息具有多个逻辑单元,则用户可以在message元素中包含多个part子元素;也可以先定义一个表示消息逻辑结构的复杂类型,然后再message元素中仅包含一个引用该类型的part子元素。
例如,下面定义的AddHttpGetin消息中包含2个part元素:
<message name="AddHttpGetin">
<part name="x" type="s:string"/>
<part name="y" type="s:string"/>
</message>

下面定义的AddSoapin消息中,则只包含一个引用复杂类型的part子元素Add:
<tpyes>
<s:element name="Add">
<s:complexType>
<s:sequence>
<s:element minOccurs="1" maxOccurs="1" name="x" type="s:int"/>
<s:element minOccurs="1" maxOccurs="1" name="y" type="s:int"/>
</s:sequence>
</s:complexType>
</tpyes>
<message name="AddSoapin">
<part name="parameters" element="s0:Add"/>
</message>
4、portType元素
表示端口类型的抽象定义,端口类型由一种抽象操作组成。在定义portType元素时,使用name属性指定它的名字。portType元素中可以包含0个或多个operation子元素,operation元素又可以包含对应于操作参数和返回结果的输入和输出消息,分别使用input和output元素表示,在这2个元素中可以使用message属性指定它们所对应的消息。例如:
<portType name="MyFirstWebServicesSoap">
<operation name="HelloWorld">
<documentation>返回字符串HelloWorld</documentation>
<input message="s0:HelloWorldSoapin"/>
<output message="s0:HelloWorldSoapOut"/>
</operation>
<operation name="Add">
<documentation>返回两个整数的和</documentation>
<input message="s0:AddSoapin"/>
<output message="s0:AddSoapOut"/>
</operation>
</portType>
5、binding元素
定义了portType元素中的operation和message元素的消息格式和协议细节。一个给定的portType可以具有任意数目的绑定。格式如下:
<wsdl:binding name="绑定名" type="端口类型名">
<wsdl:operation name="操作名">
<wsdl:input name="输入消息名">
</wsdl:input>
<wsdl:output name="输出消息名">
</wsdl:output>
<wsdl:fault name="错误消息名">
</wsdl:fault>
</wsdl:operation>
</wsdl:binding>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值