一、WSDL概述 二、WSDL基本结构 <?xml version="1.0" encoding="UTF-8"?> WSDL的声明必须定义成使用:UTF-8 或者UTF-16 编码。 3.2 definition元素 <definitions name="BookQuoteWS" targetNamespace=http://www.Monson-Haefel.com/jwsbook/BookQuote xmlns:mh=http://www.Monson-Haefel.com/jwsbook/BookQuote xmlns:soapbind="http://schemas./wsdl/soap/" xmlns:xsd=http://www./2001/XMLSchema xmlns="http://schemas./wsdl/"> definition元素中一般包括若干个XML命名空间; http://schemas./wsdl/是默认的命名空间,这样就可以不用显式地定义每一个WSDL元素的命名空间了,例如:<types> <messages> <portType>…;文档中所有的元素缺省应该属于这个命名空间。 definition元素的的一个属性是name,此属性不重要可以没有; 定义了targetNamespace命名空间,它为在模式中显式创建的所有新类型均声明了XML命名空间,而且上面的例子中赋予了mh前缀。 <!-- message elements describe the input and output parameters --> <message name="GetBookPriceRequest"> <part name="isbn" type="xsd:string" /> </message> <message name="GetBookPriceResponse"> <part name="price" type="xsd:float" /> </message> <!-- portType element describes the abstract interface of a Web service --> <portType name="BookQuote"> <operation name="getBookPrice"> <input name="isbn" message="mh:GetBookPriceRequest"/> <output name="price" message="mh:GetBookPriceResponse"/> </operation> </portType>
上面的例子中:message元素利用name属性指定了标签(例如:GetBookPriceRequest),这些标签会自动使用targetNamespace的命名空间,标签了的messages元素通常被称为定义。 <?xml version="1.0" encoding="UTF-8"?> <definitions name="BookQuoteWS" targetNamespace=http://www.Monson-Haefel.com/jwsbook/BookQuote xmlns:mh=http://www.Monson-Haefel.com/jwsbook/BookQuote xmlns:soapbind=http://schemas./wsdl/soap/ xmlns:xsd=http://www./2001/XMLSchema xmlns="http://schemas./wsdl/"> <types> <xsd:schema targetNamespace="http://www.Monson-Haefel.com/jwsbook/BookQuote"> <!-- The ISBN simple type --> <xsd:simpleType name="ISBN"> <xsd:restriction base="xsd:string"> <xsd:pattern value="[0-9]{9}[0-9Xx]" /> </xsd:restriction> </xsd:simpleType> </xsd:schema> </types> Types元素作为一个容器,用来定义XML模式内置的数据类型(即复杂类型和定制的简单类现,详细见Web Service XML文章)中没有描述的各种数据类型。例如:ISBN。 <definitions name="AllMhWebServices" xmlns="http://schemas./wsdl/"> <import namespace=http://www.Monson-Haefel.com/jwsbook/BookQuote location="http://www.Monson-Haefel.com/jwsbook/BookPrice.wsdl"/> <import namespace=http://www.Monson-Haefel.com/jwsbook/po location="http://www.Monson-Haefel.com/jwsbook/wsdl/PurchaseOrder.wsdl"/> <import namespace=http://www.Monson-Haefel.com/jwsbook/Shipping location="http://www.Monson-Haefel.com/jwsbook/wsdl/Shipping.wsdl"/> </definitions > WSDL的import元素必须声明两个属性,即namespace属性和location属性。 <message name="GetBulkBookPriceRequest"> <part name="isbn" type="xsd:string"/> <part name="quantity" type="xsd:int"/> </message> <message name="GetBulkBookPriceResponse"> <part name="price" type="mh:prices" /> </message> RPC式样的Web服务的message服务 GetBulkBookPriceRequest表示消息的输入(相当于函数的参数),GetBulkBookPriceResponse表示消息的输出(相当于函数的返回值) Web Service的输入和输出参数可以是多个(一个特点),每一个输入或者输出使用part元素定义,RPC样式必须使用type来定义类型 RPC样式用类型来数据定义过程调用,调用中的每一个元素表示某一个类型的参数。 <types> <xsd:schema targetNamespace="http://www.Monson-Haefel.com/jwsbook/PO"> <!-- Import the PurchaseOrder XML schema document --> <xsd:import namespace=http://www.Monson-Haefel.com/jwsbook/PO schemaLocation="http://www.Monson-Haefel.com/jwsbook/po.xsd" /> </xsd:schema> </types> <!-- message elements describe the input and output parameters --> <message name="SubmitPurchaseOrderMessage"> <part name="order" element="mh:purchaseOrder" /> </message> 文档式样Web服务的Messages元素: 当用户采用文档式样消息传递模式的时候,messages元素要应用types定义中的顶级元素。具体顶级元素的定义和XML schema详见Web Server XML文档。 消息部分使用element属性定义 文档式样的消息传递要交换XML文档,并且应用它们的顶级元素。 注:Messages元素的RPC/Document试样对应了SOAP RPC/Document消息传递模式,详细见Web Server SOAP相关文档 <types> <xsd:schema targetNamespace="http://www.Monson-Haefel.com/jwsbook/PO"> <!-- Import the PurchaseOrder XML schema document --> <xsd:element name="InvalidIsbnFaultDetail" > <xsd:complexType> <xsd:sequence> <xsd:element name="offending-value" type="xsd:string"/> <xsd:element name="conformance-rules" type="xsd:string" /> </xsd:sequence> </xsd:complexType> </xsd:element> </xsd:schema> </types> <!-- message elements describe the input and output parameters --> <message name="GetBookPriceRequest"> <part name="isbn" type="xsd:string" /> </message> <message name="GetBookPriceResponse"> <part name="price" type="xsd:float" /> </message> <message name="InvalidArgumentFault"> <part name="error_message" element="mh:InvalidIsbnFaultDetail" /> </message> 声明错误消息: 错误使用的消息定义只能采用Document/Literal编码样式 上面声明了匿名类型,InvalidIsbnFaultDetail不需要type类型,complexType中也不包括name属性,详细见Web Service XML相关文档。
<message name="GetBulkBookPriceRequest"> <part name="isbn" type="xsd:string"/> <part name="quantity" type="xsd:int"/> </message> <message name="GetBulkBookPriceResponse"> <part name="prices" type="mh:prices" /> </message> <message name="InvalidArgumentFault"> <part name="error_message" element="mh:InvalidIsbnFaultDetail" /> </message> <portType name="GetBulkBookPrice" > <operation name="getBulkBookPrice" parameterOrder="isbn quantity"> <input name="request" message="mh:GetBulkBookPriceRequest"/> <output name="prices" message="mh:GetBulkBookPriceResponse"/> <fault name="InvalidArgumentFault" message="mh:InvalidArgumentFault"/> </operation> </portType> Input表示传递到Web服务的有效负载;output表示返回给客户的有效负载;可以不包括,也可以包括一个或者多个fault错误消息。 parameterOrder定义了input和output消息采用的正确的顺序 使用parameterOrder的时候,必须包含所有输入参数部分;并且只包含不是返回类型的输出部分,如果output只有一个part(上例),会假设返回值,所以不包括在parameterOrder中 如果parameterOrder列出output中的part部分,那么这个将被作为OUT参数,如果input元素和output元素使用相同的名称声明了一个部分的时候,此部分为INOUT参数 4.4 WSDL消息交换模式(MEP) <service name="BookPriceService">
<port name="BookPrice_Port" binding="mh:BookPrice_Binding"> <soapbind:address location= "http://www.Monson-Haefel.com/jwsbook/BookQuote" /> </port> <port name="BookPrice_Failover_Port" binding="mh:BookPrice_Binding"> <soapbind:address location= "http://www./jwsbook/BookPrice" /> </port> <port name="SubmitPurchaseOrder_Port" binding="mh:SubmitPurchaseOrder_Binding"> <soapbind:address location= "https://www./jwsbook/po" /> </port> </service> Service元素包含一个或者多个Port元素 每一个Port元素对应一个不同的Web服务,port将一个URL赋予一个特定的binding,通过location实现 可以使两个或者多个port元素将不同的URL赋给相同的binding,例如负载平衡和容错的时候,使用这种方法。 soapbind:address:将Internet地址通过location属性赋予一个SOAP绑定。 |
|