webservice之WSDL解析

本文详细介绍了WSDL(Web Services Description Language)的五大元素:types、message、portType、binding和服务(service),并解析了每个元素在Web服务中的作用。WSDL文档通过XML格式定义,包括抽象定义和具体定义两部分,用于描述Web服务的接口、消息、协议和地址。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

webservice之WSDL文件详解

  WSDL: Web Services Description Language 网页服务描述语言

  详解WSDL文档元素:

  文件是以XML格式定义的,内容分成了5大元素:

  1、<types>:webservice使用的数据类型,它是独立以机器和语言的类型定义,这些数据类型被<message>标签所使用。

  2、<message>:webservice使用的消息,它定义了webservice函数的参数。在webservice中输入参数和输出参数需要分开定义,使用不同的message标签体。message定义的输入输出参数,被<portType>标签使用。

  3、<portType>:webservice执行操作。该标签引用<message>标签定义的函数来描述函数的签名(操作名、输入参数、输出参数)

  4、<binding>:webservice通信协议。在portType中定义的每一项操作,都在此绑定中实现。

  5、<service>:该标签定义每一绑定的端口地址。

  WSDL文档可以分为两部分。顶部分由抽象定义组成,而底部分则由具体描述组成。抽象部分以独立于平台和语言的方式定义SOAP消息,它们并不包含任何随机器或语言而变的元素。这就定义了一系列服务,截然不同的应用都可以实现。具体部分,如数据的序列化则归入底部分,因为它包含具体的定义。在上述的文档元素中,<types>、<message>、<portType>属于抽象定义层,<binding>、<service>属于具体定义层。所有的抽象可以是单独存在于别的文件中,也可以从主文档中导入。

<?xml version='1.0' encoding='UTF-8'?><wsdl:definitions name="HelloWorldService" targetNamespace="http://test.demo1/" xmlns:ns1="http://schemas.xmlsoap.org/soap/http" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://test.demo1/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:xsd="http://www.w3.org/2001/XMLSchema">  
  <wsdl:types>  
<xs:schema elementFormDefault="unqualified" targetNamespace="http://test.demo1/" version="1.0" xmlns:tns="http://test.demo1/" xmlns:xs="http://www.w3.org/2001/XMLSchema">  
<xs:element name="sayHello" type="tns:sayHello"/>  
<xs:element name="sayHelloResponse" type="tns:sayHelloResponse"/>  
<xs:complexType name="sayHello">  
<xs:sequence>  
<xs:element minOccurs="0" name="arg0" type="xs:string"/>  
</xs:sequence>  
</xs:complexType>  
<xs:complexType name="sayHelloResponse">  
<xs:sequence>  
<xs:element minOccurs="0" name="return" type="xs:string"/>  
</xs:sequence>  
</xs:complexType>  
</xs:schema>  
  </wsdl:types>  
  <wsdl:message name="sayHelloResponse">  
    <wsdl:part element="tns:sayHelloResponse" name="parameters">  
    </wsdl:part>  
  </wsdl:message>  
  <wsdl:message name="sayHello">  
    <wsdl:part element="tns:sayHello" name="parameters">  
    </wsdl:part>  
  </wsdl:message>  
  <wsdl:portType name="HelloWorld">  
    <wsdl:operation name="sayHello">  
      <wsdl:input message="tns:sayHello" name="sayHello">  
    </wsdl:input>  
      <wsdl:output message="tns:sayHelloResponse" name="sayHelloResponse">  
    </wsdl:output>  
    </wsdl:operation>  
  </wsdl:portType>  
  <wsdl:binding name="HelloWorldServiceSoapBinding" type="tns:HelloWorld">  
    <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>  
    <wsdl:operation name="sayHello">  
      <soap:operation soapAction="" style="document"/>  
      <wsdl:input name="sayHello">  
        <soap:body use="literal"/>  
      </wsdl:input>  
      <wsdl:output name="sayHelloResponse">  
        <soap:body use="literal"/>  
      </wsdl:output>  
    </wsdl:operation>  
  </wsdl:binding>  
  <wsdl:service name="HelloWorldService">  
    <wsdl:port binding="tns:HelloWorldServiceSoapBinding" name="HelloWorldPort">  
      <soap:address location="http://localhost:8080/helloWorld"/>  
    </wsdl:port>  
  </wsdl:service>  
</wsdl:definitions>  

1.WSDL文档的根元素:

  <wsdl:definitions xmlns:wsdl=""

  xmlns:ns1=""

  xmlns:ns=""

  xmlns:wsaw=""

  xmlns:http=""

  xmlns:ax21=""

  xmlns:xs=""

  xmlns:mime=""

  xmlns:soap=""

  xmlns:soap12=""

  targetNamespace="">

  <definitions>定义了文档中用到的各个xml元素的namespace缩写,也界定了本文档自己的 targetNamespace="",这意味着其它的XML要引用当前XML中的元素时,要声明这个namespace。注意xmlns:ns=""这个声明,它标示了使用ns这个前缀指向自身的命名空间。

2.WSDL文档数据类型定义元素:<types>:

  <wsdl:types>

  <xs:schema xmlns:ax22=""

  attributeFormDefault="qualified" elementFormDefault="qualified"

  targetNamespace="">

  <xs:import namespace="" />

  <xs:element name="returnBook">

  <xs:complexType>

  <xs:sequence>

  <xs:element minOccurs="0" name="isbn" nillable="true"

  type="xs:string" />

  </xs:sequence>

  </xs:complexType>

  </xs:element>

  <xs:element name="login"> <xs:complexType> <xs:sequence> <xs:element minOccurs="0" name="userName" nillable="true" type="xs:string" /> <xs:element minOccurs="0" name="passWord" nillable="true" type="xs:string" /> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="loginResponse"> <xs:complexType> <xs:sequence> <xs:element minOccurs="0" name="return" type="xs:boolean" /> </xs:sequence> </xs:complexType> </xs:element>

  这里定义webservice的一个元素名称returnBook,就是service的一个函数名称(见图),定义了混合类型数据类型,类型是string类型,名称叫isbn

3.WSDL文档消息体定义元素:< message >

  <wsdl:message name="loginRequest">

  <wsdl:part name="parameters" element="ns:login" />

  </wsdl:message>

  <wsdl:message name="loginResponse">

  <wsdl:part name="parameters" element="ns:loginResponse" />

  </wsdl:message>

  这里定义定义了消息请求,这里定义使用的消息是loginRequest和loginResponse,它分别引用了types中的login和loginResponse元素。在types中的login和loginResponse元素定义好了参数类型。有没有Response消息,主要是看你的函数是否有返回值,如果是void,想returnBook这函数就没有returnBookResponse。

4.WSDL文档操作定义元素:< portType >

  <wsdl:portType name="LibraryPortType">

  <wsdl:operation name="login">

  <wsdl:input message="ns:loginRequest" wsaw:Action="urn:login" />

  <wsdl:output message="ns:loginResponse" wsaw:Action="urn:loginResponse" />

  </wsdl:operation>

  定义了操作名称login,输入使用的消息是loginRequest,Action是urn:login,输出ns:loginResponse,Action是:urn:loginResponse

5、WSDL文档操作绑定协议<binding>:

  <wsdl:binding name="LibrarySoap11Binding" type="ns:LibraryPortType"> <soap:binding transport="" /> <wsdl:operation name="login"> <soap:operation soapAction="urn:login" /> <wsdl:input> <soap:body use="literal" /> </wsdl:input> <wsdl:output> <soap:body use="literal" /> </wsdl:output> </wsdl:operation>

  首先<binding>标签使用<soap:binding>的transport和style属性定义了Web Service的通讯协议HTTP和SOAP的请求风格RPC。其次<operation>子标签将portType中定义的 operation同SOAP的请求绑定,定义了操作名称soapAction,输出输入参数和异常的编码方式及命名空间。

  如果客户端要调用这方法就要声明是这soapAction名称urn:login。

6、WSDL文档绑定服务端口地址<service>:

  <wsdl:service name="Library"> <wsdl:port name="LibraryHttpSoap11Endpoint" binding="ns:LibrarySoap11Binding"> <soap:address location="" /> </wsdl:port> <wsdl:port name="LibraryHttpSoap12Endpoint" binding="ns:LibrarySoap12Binding"> <soap12:address location="" /> </wsdl:port> <wsdl:port name="LibraryHttpEndpoint" binding="ns:LibraryHttpBinding"> <http:address location="" /> </wsdl:port> </wsdl:service>

  这里描述webservice的服务名称是Library,service是一套<port>元素。在一一对应形式下,每个<port>元素都和一个location关联。如果同一个<binding>有多个<port>元素与之关联,可以使用额外的URL地址作为替换。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值