当你已经了解Xml的知识后,我们就来较为详细的探讨一下Web Services中的Soap消息。这里我们是基于Visual Studio.Net2005中建立的WebService和前面我们所举的例子中有关的WebService。好了我们开始来详细探讨吧!

一、Soap协议知识
1、Soap是什么
      Soap是简单对象访问协议。在1998年就已经诞生,当时只是当作RPC机制(远程过程调用)。然而人们发现Soap可以用于更广泛的用途,因此在今天的Soap1.1规范中不再有过多的限制。但是在当时缺少一种能够通用的数据描述语言,而使Soap不能得到普遍的认同。如今随着Xml的诞生和发展并于Soap的完美结合,使Soap得到了大多数人的青睐,同时也使Web Services得到了推广。
      Soap和Http一样都是一种应用级的协议,使用它可在不同的应用程序之间方便的交换数据。Soap除了可以基于Http协议外,还可以其他的任何传输协议实现应用程序到应用程序的通信。

2、Soap的结构
      正如在《Web服务初探:用Demo学Web服务系列(7)——XML的相关知识》中我们所举的例子那样,Soap消息是由一个信封组成,这个信封定义了消息的总体结构。包含在信封中的是消息头信息(可选)和消息体信息(必选)。消息头和消息体并没有在Soap规范中定义,这些信息是特定于使用Soap消息的系统的。如果需要使用错误消息,则错误消息被包含在消息体中。
      下面给出一个简单的Soap消息例子:
 17.Web服务中Soap消息的相关知识<?xml version="1.0" ?>
 27.Web服务中Soap消息的相关知识<soap:Envelop xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
 37.Web服务中Soap消息的相关知识      <soap:Header>
 47.Web服务中Soap消息的相关知识            <!-- 这里是消息头内容 -->
 57.Web服务中Soap消息的相关知识      </soap:Header>
 67.Web服务中Soap消息的相关知识      <soap:Body>
 77.Web服务中Soap消息的相关知识            <!-- 这里是消息体内容 -->
 87.Web服务中Soap消息的相关知识      </soap:Body>
 97.Web服务中Soap消息的相关知识</soap:Envelop>7.Web服务中Soap消息的相关知识
(1)、Soap消息头部分
      Soap消息的创建者可以把任意元素放在这个部分,这个部分组成了Soap消息的消息头信息。在处理Web Services时,这个部分也许是完全没有必要的。即便如此,我们也还是要了解Soap消息头中的两个有用的属性:指定消息头所瞄准的端点类型(artor属性),这个属性我们很少会用到,所以在这里就不多说了;消息头是否必须被处理(mustUnderstand属性),当值为“1”或者是“true”时,则消息头就必须被Web Services处理。关于消息头的使用我们在前面的Demo中已经讲解和使用过了,那么上次的Demo中我们所产生的Soap消息头是什么样子的呢,请看下面的例子:

      综上可以看出,消息头信息对于保存和消息的语义不是直接相关的上下文信息是很有用的。

(2)、Soap消息体部分
      和Soap消息头部分一样,Soap消息体的内容完全取决于在被瞄准的Web Services的语义中指定的消息定义。说确切点就是,内容是由和Web Services相关的WSDL文档定义的。
      下面我们分别来看在前面的随笔中的Demo中每个方法所产生的Soap消息内容如下:
 17.Web服务中Soap消息的相关知识<!-- 这里是Login的Soap消息,在运行前面Demo中的MyServiceClass时会看见此请求和响应的Soap消息 -->
 27.Web服务中Soap消息的相关知识POST /WebServicesDemo/MyServiceClass.asmx HTTP/1.1
 37.Web服务中Soap消息的相关知识Host: localhost
 47.Web服务中Soap消息的相关知识Content-Type: application/soap+xml; charset=utf-8
 57.Web服务中Soap消息的相关知识Content-Length: length
 67.Web服务中Soap消息的相关知识
 77.Web服务中Soap消息的相关知识<?xml version="1.0" encoding="utf-8"?>
 87.Web服务中Soap消息的相关知识<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
 97.Web服务中Soap消息的相关知识  <soap12:Header>
107.Web服务中Soap消息的相关知识    <MyServiceClassHeader xmlns="http://tempuri.org/">
117.Web服务中Soap消息的相关知识      <UsN>string</UsN>
127.Web服务中Soap消息的相关知识      <PaW>string</PaW>
137.Web服务中Soap消息的相关知识    </MyServiceClassHeader>
147.Web服务中Soap消息的相关知识  </soap12:Header>
157.Web服务中Soap消息的相关知识  <soap12:Body>
167.Web服务中Soap消息的相关知识    <Login xmlns="http://tempuri.org/" />
177.Web服务中Soap消息的相关知识  </soap12:Body>
187.Web服务中Soap消息的相关知识</soap12:Envelope>
197.Web服务中Soap消息的相关知识<!-- 上面的是请求Soap消息 -->
207.Web服务中Soap消息的相关知识
217.Web服务中Soap消息的相关知识HTTP/1.1 200 OK
227.Web服务中Soap消息的相关知识Content-Type: application/soap+xml; charset=utf-8
237.Web服务中Soap消息的相关知识Content-Length: length
247.Web服务中Soap消息的相关知识
257.Web服务中Soap消息的相关知识<?xml version="1.0" encoding="utf-8"?>
267.Web服务中Soap消息的相关知识<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
277.Web服务中Soap消息的相关知识  <soap12:Body>
287.Web服务中Soap消息的相关知识    <LoginResponse xmlns="http://tempuri.org/">
297.Web服务中Soap消息的相关知识      <LoginResult>string</LoginResult>
307.Web服务中Soap消息的相关知识    </LoginResponse>
317.Web服务中Soap消息的相关知识  </soap12:Body>
327.Web服务中Soap消息的相关知识</soap12:Envelope>
337.Web服务中Soap消息的相关知识<!-- 上面是响应Soap消息 -->
 17.Web服务中Soap消息的相关知识<!-- 这里是SelectUser的Soap消息,在运行前面Demo中的MyServiceClass时会看见此请求和响应的Soap消息 -->
 27.Web服务中Soap消息的相关知识POST /WebServicesDemo/MyServiceClass.asmx HTTP/1.1
 37.Web服务中Soap消息的相关知识Host: localhost
 47.Web服务中Soap消息的相关知识Content-Type: application/soap+xml; charset=utf-8
 57.Web服务中Soap消息的相关知识Content-Length: length
 67.Web服务中Soap消息的相关知识
 77.Web服务中Soap消息的相关知识<?xml version="1.0" encoding="utf-8"?>
 87.Web服务中Soap消息的相关知识<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
 97.Web服务中Soap消息的相关知识  <soap12:Body>
107.Web服务中Soap消息的相关知识    <SelectUser xmlns="http://tempuri.org/">
117.Web服务中Soap消息的相关知识      <UserName>string</UserName>
127.Web服务中Soap消息的相关知识    </SelectUser>
137.Web服务中Soap消息的相关知识  </soap12:Body>
147.Web服务中Soap消息的相关知识</soap12:Envelope>
157.Web服务中Soap消息的相关知识<!-- 上面是请求Soap消息 -->
167.Web服务中Soap消息的相关知识
177.Web服务中Soap消息的相关知识HTTP/1.1 200 OK
187.Web服务中Soap消息的相关知识Content-Type: application/soap+xml; charset=utf-8
197.Web服务中Soap消息的相关知识Content-Length: length
207.Web服务中Soap消息的相关知识
217.Web服务中Soap消息的相关知识<?xml version="1.0" encoding="utf-8"?>
227.Web服务中Soap消息的相关知识<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
237.Web服务中Soap消息的相关知识  <soap12:Body>
247.Web服务中Soap消息的相关知识    <SelectUserResponse xmlns="http://tempuri.org/">
257.Web服务中Soap消息的相关知识      <SelectUserResult>
267.Web服务中Soap消息的相关知识        <xsd:schema>schema</xsd:schema>xml</SelectUserResult>
277.Web服务中Soap消息的相关知识    </SelectUserResponse>
287.Web服务中Soap消息的相关知识  </soap12:Body>
297.Web服务中Soap消息的相关知识</soap12:Envelope>
307.Web服务中Soap消息的相关知识<!-- 上面是响应Soap消息 -->
      其中的以黄色底显示的部分在Soap消息真正使用时会用实际的相应数据类型值所替代。

3、Soap中的Namespace
      值得一提的是,在所有的Soap消息中都能看到Namespace,这个到底是有什么用处的呢?我们知道在Xml中有很多描述数据的标记,然而有时候同一个标记在不同的地方有不同的意义,因此为了区分它们我们就必须为相同的标记表示的不同的含义指定Namespace,而指定Namespace也并不是随便的一个值,必须是类似于虚拟地址的书写格式,如:Namespace="http://www.microsoft.com/MyService",这里的网址不一定非要是可以连接的。

二、WSDL文档
1、WSDL扩展
      如果不和具体的协议一起使用,WSDL定义就没有那么有用了,你可以自己定义协议,也可以使用Soap协议和Http协议这两个协议也就足够了。

2、什么是WSDL文档
      如果单独提及WSDL这个名词,它常常表示用于描述Web服务的语法规范。但如果同时提到某个Web Services,那它就表示这个Web Services的说明文档。
      WSDL文档是对一个Web Services的位置、协议和接口详细且明确的说明。它由Web Services的开发者提供,现在已经有能够根据Web Services的代码自动生成WSDL文档的工具了。虽然如此,Web Services的开发者也可以自己手工编写,因为WSDL文档也是Xml文件,只是编写的时候必须严格遵守WSDL规范的要求。

3、WSDL文档结构
      WSDL文档的根元素是<definitions>,其中包括多种子元素。这些子元素总体上可以分为两类:一类位于文档的前半部分,它们构成Web Services的“具体说明”。抽象部分是独立于平台和程序语言的方式来描述Web Services,比如Web方法的参数类型;后一部分指定Web Services的具体内容,比如传输协议。
      抽象定义部分包括三个元素:Types,独立于机器和程序语言的类型定义。Messages,包含方法参数(输入和输出分开)或消息文档说明。PortTypes,使用Messages部分的消息定义来描述方法的签名(操作名称、输入参数和输出参数)。在PortTypes中具体说明时又包含两个元素:Bindings,指定PortTypes部分中每个操作的绑定信息。Services,指定每个绑定的Port地址。
      抽象定义和具体说明,既是有一定的各自独立性,又有一定的相互关联性。还要说明的是在一个WSDL文档中可以没有Types部分,但如果有那么就只能有一个。
      下面就来看看我们在前面的随笔中的Demo中所产生的WSDL文档,原文件如下:
  17.Web服务中Soap消息的相关知识<?xml version="1.0" encoding="utf-8"?>
  27.Web服务中Soap消息的相关知识<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tm="http://microsoft.com/wsdl/mime/textMatching/" xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/" xmlns:tns="http://tempuri.org/" xmlns:s="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" targetNamespace="http://tempuri.org/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
  37.Web服务中Soap消息的相关知识  <wsdl:types>
  47.Web服务中Soap消息的相关知识    <s:schema elementFormDefault="qualified" targetNamespace="http://tempuri.org/">
  57.Web服务中Soap消息的相关知识      <s:element name="Login">
  67.Web服务中Soap消息的相关知识        <s:complexType />
  77.Web服务中Soap消息的相关知识      </s:element>
  87.Web服务中Soap消息的相关知识      <s:element name="LoginResponse">
  97.Web服务中Soap消息的相关知识        <s:complexType>
 107.Web服务中Soap消息的相关知识          <s:sequence>
 117.Web服务中Soap消息的相关知识            <s:element minOccurs="0" maxOccurs="1" name="LoginResult" type="s:string" />
 127.Web服务中Soap消息的相关知识          </s:sequence>
 137.Web服务中Soap消息的相关知识        </s:complexType>
 147.Web服务中Soap消息的相关知识      </s:element>
 157.Web服务中Soap消息的相关知识      <s:element name="MyServiceClassHeader" type="tns:MyServiceClassHeader" />
 167.Web服务中Soap消息的相关知识      <s:complexType name="MyServiceClassHeader">
 177.Web服务中Soap消息的相关知识        <s:sequence>
 187.Web服务中Soap消息的相关知识          <s:element minOccurs="0" maxOccurs="1" name="UsN" type="s:string" />
 197.Web服务中Soap消息的相关知识          <s:element minOccurs="0" maxOccurs="1" name="PaW" type="s:string" />
 207.Web服务中Soap消息的相关知识        </s:sequence>
 217.Web服务中Soap消息的相关知识        <s:anyAttribute />
 227.Web服务中Soap消息的相关知识      </s:complexType>
 237.Web服务中Soap消息的相关知识      <s:element name="SelectUser">
 247.Web服务中Soap消息的相关知识        <s:complexType>
 257.Web服务中Soap消息的相关知识          <s:sequence>
 267.Web服务中Soap消息的相关知识            <s:element minOccurs="0" maxOccurs="1" name="UserName" type="s:string" />
 277.Web服务中Soap消息的相关知识          </s:sequence>
 287.Web服务中Soap消息的相关知识        </s:complexType>
 297.Web服务中Soap消息的相关知识      </s:element>
 307.Web服务中Soap消息的相关知识      <s:element name="SelectUserResponse">
 317.Web服务中Soap消息的相关知识        <s:complexType>
 327.Web服务中Soap消息的相关知识          <s:sequence>
 337.Web服务中Soap消息的相关知识            <s:element minOccurs="0" maxOccurs="1" name="SelectUserResult">
 347.Web服务中Soap消息的相关知识              <s:complexType>
 357.Web服务中Soap消息的相关知识                <s:sequence>
 367.Web服务中Soap消息的相关知识                  <s:element ref="s:schema" />
 377.Web服务中Soap消息的相关知识                  <s:any />
 387.Web服务中Soap消息的相关知识                </s:sequence>
 397.Web服务中Soap消息的相关知识              </s:complexType>
 407.Web服务中Soap消息的相关知识            </s:element>
 417.Web服务中Soap消息的相关知识          </s:sequence>
 427.Web服务中Soap消息的相关知识        </s:complexType>
 437.Web服务中Soap消息的相关知识      </s:element>
 447.Web服务中Soap消息的相关知识    </s:schema>
 457.Web服务中Soap消息的相关知识  </wsdl:types>
 467.Web服务中Soap消息的相关知识  <wsdl:message name="LoginSoapIn">
 477.Web服务中Soap消息的相关知识    <wsdl:part name="parameters" element="tns:Login" />
 487.Web服务中Soap消息的相关知识  </wsdl:message>
 497.Web服务中Soap消息的相关知识  <wsdl:message name="LoginSoapOut">
 507.Web服务中Soap消息的相关知识    <wsdl:part name="parameters" element="tns:LoginResponse" />
 517.Web服务中Soap消息的相关知识  </wsdl:message>
 527.Web服务中Soap消息的相关知识  <wsdl:message name="LoginMyServiceClassHeader">
 537.Web服务中Soap消息的相关知识    <wsdl:part name="MyServiceClassHeader" element="tns:MyServiceClassHeader" />
 547.Web服务中Soap消息的相关知识  </wsdl:message>
 557.Web服务中Soap消息的相关知识  <wsdl:message name="SelectUserSoapIn">
 567.Web服务中Soap消息的相关知识    <wsdl:part name="parameters" element="tns:SelectUser" />
 577.Web服务中Soap消息的相关知识  </wsdl:message>
 587.Web服务中Soap消息的相关知识  <wsdl:message name="SelectUserSoapOut">
 597.Web服务中Soap消息的相关知识    <wsdl:part name="parameters" element="tns:SelectUserResponse" />
 607.Web服务中Soap消息的相关知识  </wsdl:message>
 617.Web服务中Soap消息的相关知识  <wsdl:portType name="MyServiceClassSoap">
 627.Web服务中Soap消息的相关知识    <wsdl:operation name="Login">
 637.Web服务中Soap消息的相关知识      <wsdl:input message="tns:LoginSoapIn" />
 647.Web服务中Soap消息的相关知识      <wsdl:output message="tns:LoginSoapOut" />
 657.Web服务中Soap消息的相关知识    </wsdl:operation>
 667.Web服务中Soap消息的相关知识    <wsdl:operation name="SelectUser">
 677.Web服务中Soap消息的相关知识      <wsdl:input message="tns:SelectUserSoapIn" />
 687.Web服务中Soap消息的相关知识      <wsdl:output message="tns:SelectUserSoapOut" />
 697.Web服务中Soap消息的相关知识    </wsdl:operation>
 707.Web服务中Soap消息的相关知识  </wsdl:portType>
 717.Web服务中Soap消息的相关知识  <wsdl:binding name="MyServiceClassSoap" type="tns:MyServiceClassSoap">
 727.Web服务中Soap消息的相关知识    <soap:binding transport="http://schemas.xmlsoap.org/soap/http" />
 737.Web服务中Soap消息的相关知识    <wsdl:operation name="Login">
 747.Web服务中Soap消息的相关知识      <soap:operation soapAction="http://tempuri.org/Login" style="document" />
 757.Web服务中Soap消息的相关知识      <wsdl:input>
 767.Web服务中Soap消息的相关知识        <soap:body use="literal" />
 777.Web服务中Soap消息的相关知识        <soap:header message="tns:LoginMyServiceClassHeader" part="MyServiceClassHeader" use="literal" />
 787.Web服务中Soap消息的相关知识      </wsdl:input>
 797.Web服务中Soap消息的相关知识      <wsdl:output>
 807.Web服务中Soap消息的相关知识        <soap:body use="literal" />
 817.Web服务中Soap消息的相关知识      </wsdl:output>
 827.Web服务中Soap消息的相关知识    </wsdl:operation>
 837.Web服务中Soap消息的相关知识    <wsdl:operation name="SelectUser">
 847.Web服务中Soap消息的相关知识      <soap:operation soapAction="http://tempuri.org/SelectUser" style="document" />
 857.Web服务中Soap消息的相关知识      <wsdl:input>
 867.Web服务中Soap消息的相关知识        <soap:body use="literal" />
 877.Web服务中Soap消息的相关知识      </wsdl:input>
 887.Web服务中Soap消息的相关知识      <wsdl:output>
 897.Web服务中Soap消息的相关知识        <soap:body use="literal" />
 907.Web服务中Soap消息的相关知识      </wsdl:output>
 917.Web服务中Soap消息的相关知识    </wsdl:operation>
 927.Web服务中Soap消息的相关知识  </wsdl:binding>
 937.Web服务中Soap消息的相关知识  <wsdl:binding name="MyServiceClassSoap12" type="tns:MyServiceClassSoap">
 947.Web服务中Soap消息的相关知识    <soap12:binding transport="http://schemas.xmlsoap.org/soap/http" />
 957.Web服务中Soap消息的相关知识    <wsdl:operation name="Login">
 967.Web服务中Soap消息的相关知识      <soap12:operation soapAction="http://tempuri.org/Login" style="document" />
 977.Web服务中Soap消息的相关知识      <wsdl:input>
 987.Web服务中Soap消息的相关知识        <soap12:body use="literal" />
 997.Web服务中Soap消息的相关知识        <soap12:header message="tns:LoginMyServiceClassHeader" part="MyServiceClassHeader" use="literal" />
1007.Web服务中Soap消息的相关知识      </wsdl:input>
1017.Web服务中Soap消息的相关知识      <wsdl:output>
1027.Web服务中Soap消息的相关知识        <soap12:body use="literal" />
1037.Web服务中Soap消息的相关知识      </wsdl:output>
1047.Web服务中Soap消息的相关知识    </wsdl:operation>
1057.Web服务中Soap消息的相关知识    <wsdl:operation name="SelectUser">
1067.Web服务中Soap消息的相关知识      <soap12:operation soapAction="http://tempuri.org/SelectUser" style="document" />
1077.Web服务中Soap消息的相关知识      <wsdl:input>
1087.Web服务中Soap消息的相关知识        <soap12:body use="literal" />
1097.Web服务中Soap消息的相关知识      </wsdl:input>
1107.Web服务中Soap消息的相关知识      <wsdl:output>
1117.Web服务中Soap消息的相关知识        <soap12:body use="literal" />
1127.Web服务中Soap消息的相关知识      </wsdl:output>
1137.Web服务中Soap消息的相关知识    </wsdl:operation>
1147.Web服务中Soap消息的相关知识  </wsdl:binding>
1157.Web服务中Soap消息的相关知识  <wsdl:service name="MyServiceClass">
1167.Web服务中Soap消息的相关知识    <wsdl:port name="MyServiceClassSoap" binding="tns:MyServiceClassSoap">
1177.Web服务中Soap消息的相关知识      <soap:address location="http://localhost/WebServicesDemo/MyServiceClass.asmx" />
1187.Web服务中Soap消息的相关知识    </wsdl:port>
1197.Web服务中Soap消息的相关知识    <wsdl:port name="MyServiceClassSoap12" binding="tns:MyServiceClassSoap12">
1207.Web服务中Soap消息的相关知识      <soap12:address location="http://localhost/WebServicesDemo/MyServiceClass.asmx" />
1217.Web服务中Soap消息的相关知识    </wsdl:port>
1227.Web服务中Soap消息的相关知识  </wsdl:service>
1237.Web服务中Soap消息的相关知识</wsdl:definitions>
      从上面的WSDL文档中能非常容易的看见WSDL文档被分开为两个部分了,那就是在第45行和第46行。你能读懂这个WSDL文档吗?
      学会读WSDL文档有助于你在调用他人开发的Web Services时的理解和使用,WSDL文档就如同对Web Services使用的说明书,这就是我们为什么要讲解WSDL文档的一些内容的原因。

相关文章:

  • 2021-06-21
  • 2022-12-23
  • 2021-08-28
  • 2022-12-23
  • 2021-07-21
  • 2021-04-07
  • 2021-11-17
  • 2021-10-14
猜你喜欢
  • 2021-07-26
  • 2021-10-14
  • 2021-06-06
  • 2022-12-23
  • 2021-08-21
  • 2021-10-07
  • 2021-07-29
相关资源
相似解决方案