- 浏览: 268327 次
- 性别:
- 来自: 天津
-
文章分类
- 全部博客 (180)
- J2SE (15)
- J2EE (7)
- Struts (2)
- Hibernate (18)
- Spring (22)
- ssh (2)
- HTML (1)
- JS (10)
- CSS (3)
- jQuery (15)
- extJS (0)
- FLEX (14)
- Web service (7)
- Axis2 (3)
- lucene2.0 (9)
- maven (3)
- JBoss (0)
- WebLogic (0)
- Linux (8)
- Android (0)
- SiteMesh (1)
- JPA (0)
- JBPM (1)
- xFire (3)
- XML (4)
- apache (4)
- bingo专区 (0)
- 加密解密算法研究 (1)
- 数据库 (16)
- 资料 (1)
- 经验 (4)
- 健康 (1)
- 技术交流区 (1)
- 交友区 (0)
- jquery 插件区 (1)
最新评论
-
forrest_lv:
很有帮助
Axis2 XFire CXF 比较 -
kuloujianzun:
...
flex DataGrid -
zx.peng:
大哥,请教一下...
下面在别的地方引入:(在什么地方、怎么 ...
FLEX下拉多选框 -
elvislee030:
试试去,正好要找这个组件。。先谢过
FLEX下拉多选框 -
futrueboy:
如果你发到网上来,请翻译的好点
Apache Mina的学习应用(三)
七、数组
XSD提供<list>结构来声明一个数组,元素之间有空格界定。不过SOAP不是使用XSD来编码数组的,它定义了自己的数组类型--”SOAP-ENC: Array”。下列的例子揭示了从这一类型派生出一位整数数组的方法:
<xsd:complexType name=“ArrayOfInt”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“xsd:int[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
新的complex类型从soapenc:array限制派生。然后又声明了complex类型的一个属性。引用”soapenc:arrayType”实际上是这样完成的:
<xsd:attribute name=“arrayType” type=“xsd:string”/>
wsdl:arrayType属性值决定了数组每个成员的类型。数组的成员也可以是Complex类型。:
<xsd:complexType name=“ArrayOfPERSON”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“typens:PERSON[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
WSDL要求数组的类型由”ArrayOf”和每个数组元素的类型串联而成。很显然,顾名思义,”ArrayOfPERSON”是PERSON结构的数组。下面我将使用ArrayOfPERSON来声明一个<message>,并加入不止一个PERSON:
<?xml version=“1.0” encoding=“UTF-8” ?>
<definitions name=“FooSample”
targetNamespace=“http://tempuri.org/wsdl/”
xmlns:wsdlns=“http://tempuri.org/wsdl/”
xmlns:typens=“http://tempuri.org/xsd”
xmlns:xsd=“http://www.w3.org/2001/XMLSchema”
xmlns:soap=“http://schemas.xmlsoap.org/wsdl/soap/”
xmlns:stk=“http://schemas.microsoft.com/soap-toolkit/wsdl-extension”
xmlns=“http://schemas.xmlsoap.org/wsdl/”>
<types>
<schema targetNamespace=“someNamespace” xmlns:typens=“someNamespace” >
<xsd:complexType name=“PERSON”>
<xsd:sequence>
<xsd:element name=“firstName” type=“xsd:string”/>
<xsd:element name=“lastName” type=“xsd:string”/>
<xsd:element name=“ageInYears” type=“xsd:int”/>
<xsd:element name=“weightInLbs” type=“xsd:float”/>
<xsd:element name=“heightInInches” type=“xsd:float”/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name=“ArrayOfPERSON”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“typens:PERSON[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
</schema>
</types>
<message name=“addPersons”>
<part name=“person” type=“typens:ArrayOfPERSON”/>
</message>
<message name=“addPersonResponse”>
<part name=“result” type=“xsd:int”/>
</message>
</definitions>
八、<portType>和<operation>元素
PortType定义了一些抽象的操作。PortType中的operation元素定义了调用PortType中所有方法的语法,每一个operation元素声明了方法的名称、参数(使用<message>元素)和各自的类型(<part>元素要在所有<message>中声明)。
在一篇WSDL文档中可以有几个<PortType>元素,每一个都和一些相关操作放在一起,就和COM和一组操作的接口相似。
在<operation>元素中,可能会有至多一个<input>元素,一个<output>元素,以及一个<fault>元素。三个元素各有一个名字和一个消息属性。
<input>, <output>, <fault>元素属性的名字有何含义呢?它们可以用来区别两个同名操作(重载)。例如,看下面两个C函数:
void foo(int arg);
void foo(string arg);
这种重载在WSDL中可以这样表示:
<?xml version=“1.0” encoding=“UTF-8” ?>
<definitions name=“fooDescription”
targetNamespace=“http://tempuri.org/wsdl/”
xmlns:wsdlns=“http://tempuri.org/wsdl/”
xmlns:typens=“http://tempuri.org/xsd”
xmlns:xsd=“http://www.w3.org/2001/XMLSchema”
xmlns:soap=“http://schemas.xmlsoap.org/wsdl/soap/”
xmlns:stk=“http://schemas.microsoft.com/soap-toolkit/wsdl-extension”
xmlns=“http://schemas.xmlsoap.org/wsdl/”>
<types>
<schema targetNamespace=“http://tempuri.org/xsd”
xmlns=“http://www.w3.org/2001/XMLSchema”
xmlns:SOAP-ENC=“http://schemas.xmlsoap.org/soap/encoding/”
xmlns:wsdl=“http://schemas.xmlsoap.org/wsdl/”
elementFormDefault=“qualified” >
</schema>
</types>
<message name=“foo1”>
<part name=“arg” type=“xsd:int”/>
</message>
<message name=“foo2”>
<part name=“arg” type=“xsd:string”/>
</message>
<portType name=“fooSamplePortType”>
<operation name=“foo” parameterOrder=“arg “ >
<input name=“foo1” message=“wsdlns:foo1”/>
</operation>
<operation name=“foo” parameterOrder=“arg “ >
<input name=“foo2” message=“wsdlns:foo2”/>
</operation>
</portType>
<binding name=“fooSampleBinding” type=“wsdlns:fooSamplePortType”>
<stk:binding preferredEncoding=“UTF-8” />
<soap:binding style=“rpc” transport=“http://schemas.xmlsoap.org/soap/http”/>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo1”/>
<input name=“foo1”>
<soap:body use=“encoded” namespace=http://tempuri.org/message/ encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo2”/>
<input name=“foo2”>
<soap:body use=“encoded” namespace=“http://tempuri.org/message/” encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
</binding>
<service name=“FOOService”>
<port name=“fooSamplePort” binding=“fooSampleBinding”>
<soap:address location=“http://carlos:8080/fooService/foo.asp”/>
</port>
</service>
</definitions>
到目前为止,还没有一种SOAP的实现支持重载。这对基于JAVA的客户端十分重要,因为JAVA服务器使用的接口用到JAVA的重载特性。而对基于COM的客户端,就不那么重要,因为COM是不支持重载的。
九、<binding>和<operation>元素
Binding栏是完整描述协议、序列化和编码的地方,Types, Messages和PortType栏处理抽象的数据内容,而Binding栏是处理数据传输的物理实现。Binding栏把前三部分的抽象定义具体化。
把相关的数据制定和消息声明分开,这意味着同一类型服务的提供者可以把一系列的操作标准化。每个提供者可以提供定制的binding来互相区分。WSDL也有一个重要的结构,使抽象定义可以放在分离的文件中,而不是和Bindings和Services在一起,这样可在不同的服务提供者之间提供标准化的抽象定义,这很有帮助。例如,银行可以用WSDL文档来标准化一些银行的操作。每个银行仍然可以自由的订制下层的协议、串行优化,及编码。
下面是重载的WSDL示例 的Binding栏,重复在此以便讨论:
<binding name=“fooSampleBinding” type=“wsdlns:fooSamplePortType”>
<stk:binding preferredEncoding=“UTF-8” />
<soap:binding style=“rpc” transport=“http://schemas.xmlsoap.org/soap/http”/>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo1”/>
<input name=“foo1”>
<soap:body use=“encoded” namespace=http://tempuri.org/message/ encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo2”/>
<input name=“foo2”>
<soap:body use=“encoded” namespace=“http://tempuri.org/message/” encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
</binding>
<binding>元素已经取了一个名字(本例中”fooSampleBinding”),这样就可以被Services栏的<port>元素引用了。它有一个”type”的属性引用<portType>,本例中就是”wsdlns:fooSamplePortType”。第二行是MSTK2的扩展元素<stk:binding>,它指定了preferredEncoding属性为”UTF-8”。
<soap:binding>元素指定了所使用的风格(”rpc”)和传输方式。Transport属性应用了一个namespace,正是这个namespace指明使用HTTP SOAP协议。
有两个同以”foo”命名的<operation>元素。唯一不同的是它们各自的<input>名字,分别为”foo1”和”foo2”。两个<operation>元素中的<soap:operation>元素有同样的”soapAction”属性,是URI。soapAction属性是SOAP特定的URI,它只是简单的使用于SOAP消息。所产生的SOAP消息有一个SOAPAction头,而URI也仅在<soap:operation>元素里才起作用。soapAction属性在HTTP的binding中是必需的,但在其他非HTTP binding中却不要提供。目前它的使用并不清楚,但它似乎有助于本例中的两个”foo”操作。SOAP 1.1指明soapAction用来确定消息的”意图”。似乎服务器可以在不解析整个消息的情况下就能使用这一属性来发送消息。实际上,它的使用多种多样。<soap:operation>元素也可以包含另一属性,即”style”属性,在有必要冲突<soap:binding>元素指定的风格时可以使用。
<operation>属性可以包含<input>, <output> 和<fault>的元素,它们都对应于PortType栏中的相同元素。只有<input>元素在上例中提供。这三个元素中的每一个可有一个可选的”name”属性,在本例中,我们用这种方法来区分同名操作。在本例的<input>元素中有一个<soap:body>元素,它指定了哪些信息被写进SOAP消息的信息体中。该元素有以下属性:
Use
用于制定数据是”encoded”还是”literal”。”Literal”指结果SOAP消息包含以抽象定义(Types, Messages, 和PortTypes)指定格式存在的数据。”Encoded”指”encodingStyle”属性决定了编码方式。
Namespace
每个SOAP消息体可以有其自己的namespace来防止命名冲突。这一属性制定的URI在结果SOAP消息中逐字使用。
EncodingStyle
对SOAP编码,它应该有以下URI值:
“http://schemas.xmlsoap.org/soap/encoding”
十、文档风格实现
在前几栏中,<soap:binding>元素有一个类型(style)属性,设为”rpc”。此属性设为”document”时会改变传输时消息的串行化。不同于函数签名,现在的消息是文档传输的。在这类binding中,<message>元素定义文档格式,而不是函数签名。作为例子,考虑以下WSDL片段:
<definitions
xmlns:stns=“(SchemaTNS)”
xmlns:wtns=“(WsdlTNS)”
targetNamespace=“(WsdlTNS)”>
<schema targetNamespace=“(SchemaTNS)” elementFormDefault=“qualified”>
<element name=“SimpleElement” type=“xsd:int”/>
<element name=“CompositElement” type=“stns:CompositeType”/>
<complexType name=“CompositeType”>
<all>
<element name='a' type=“xsd:int”/>
<element name='b' type=“xsd:string”/>
</all>
</complexType>
</schema>
<message...>
<part name='p1' type=“stns:CompositeType”/>
<part name='p2' type=“xsd:int”/>
<part name='p3' element=“stns:SimpleElement”/>
<part name='p4' element=“stns:CompositeElement”/>
</message>
…
</definitions>
schema有两个元素:SimpleElement和CompositeElement,还有一个类型声明(CompositeType)。唯一声明的<message>元素有四个部分:p1:Composite型;p2:int型;p3:SimpleElement型;p4:CompositeElement型。以下有一个表,对四种类型的use/type决定的binding作一比较:rpc/literal, document/literal, rpc/encoded, 以及document/encoded。表指明了每种binding的表现。
十一、<service>和<port>元素
service是一套<port>元素。在一一对应形式下,每个<port>元素都和一个location关联。如果同一个<binding>有多个<port>元素与之关联,可以使用额外的URL地址作为替换。
一个WSDL文档中可以有多个<service>元素,而且多个<service>元素十分有用,其中之一就是可以根据目标URL来组织端口。这样,我就可以方便的使用另一个<service>来重定向我的股市查询申请。我的客户端程序仍然工作,因为这种根据协议归类的服务不随服务而变化。多个<service>元素的另一个作用是根据特定的协议划分端口。例如,我可以把所有的HTTP端口放在同一个<service>中,所有的SMTP端口放在另一个<service>里。我的客户可以搜索与它可以处理的协议相匹配的<service>。
<service name=“FOOService”>
<port name=“fooSamplePort” binding=“fooSampleBinding”>
<soap:address location=“http://carlos:8080/fooService/foo.asp”/>
</port>
</service>
在一个WSDL文档中,<service>的name属性用来区分不同的service。因为同一个service中可以有多个端口,它们也有”name”属性。
总结
本文中我描述了WSDL文档关于SOAP方面的最显著的特点。不过应该说明的是WSDL并不仅限于HTTP上的SOAP。WSDL用来描述HTTP-POST、HTTP-GET、SMTP及其他协议时非常清晰。使用了WSDL,SOAP更加容易处理了,无论是开发者还是使用者。我相信WSDL和SOAP一起将会开创网络应用程序世界的新时代。
WSDL的namespace里有一系列的XML元素。下表概述了那些元素、它们的属性和内容。
元素 属性 内容(子元素)
<definitions> name
targetNamespace
xmlns (other namespaces) <types>
<message>
<portType>
<binding>
<service>
<types> (none) <xsd:schema>
<message> Name <part>
<portType> Name <operation>
<binding> name
type <operation>
<service> name <port>
<part> name
type (empty)
<operation> name
parameterOrder <input>
<output>
<fault>
<input> name
message (empty)
<output> name
message (empty)
<fault> name
message (empty)
<port> name
binding <soap:address>
资源:
1. WSDL 1.1
2. SOAP 1.1
3. XML Schema Primer
4. MS SOAP Toolkit Download Site
5. A tool for translating IDL to WSDL
6. Free Web Services resources including a WSDL to VB proxy generator
7. PocketSOAP: SOAP related components, tools & source code
XSD提供<list>结构来声明一个数组,元素之间有空格界定。不过SOAP不是使用XSD来编码数组的,它定义了自己的数组类型--”SOAP-ENC: Array”。下列的例子揭示了从这一类型派生出一位整数数组的方法:
<xsd:complexType name=“ArrayOfInt”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“xsd:int[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
新的complex类型从soapenc:array限制派生。然后又声明了complex类型的一个属性。引用”soapenc:arrayType”实际上是这样完成的:
<xsd:attribute name=“arrayType” type=“xsd:string”/>
wsdl:arrayType属性值决定了数组每个成员的类型。数组的成员也可以是Complex类型。:
<xsd:complexType name=“ArrayOfPERSON”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“typens:PERSON[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
WSDL要求数组的类型由”ArrayOf”和每个数组元素的类型串联而成。很显然,顾名思义,”ArrayOfPERSON”是PERSON结构的数组。下面我将使用ArrayOfPERSON来声明一个<message>,并加入不止一个PERSON:
<?xml version=“1.0” encoding=“UTF-8” ?>
<definitions name=“FooSample”
targetNamespace=“http://tempuri.org/wsdl/”
xmlns:wsdlns=“http://tempuri.org/wsdl/”
xmlns:typens=“http://tempuri.org/xsd”
xmlns:xsd=“http://www.w3.org/2001/XMLSchema”
xmlns:soap=“http://schemas.xmlsoap.org/wsdl/soap/”
xmlns:stk=“http://schemas.microsoft.com/soap-toolkit/wsdl-extension”
xmlns=“http://schemas.xmlsoap.org/wsdl/”>
<types>
<schema targetNamespace=“someNamespace” xmlns:typens=“someNamespace” >
<xsd:complexType name=“PERSON”>
<xsd:sequence>
<xsd:element name=“firstName” type=“xsd:string”/>
<xsd:element name=“lastName” type=“xsd:string”/>
<xsd:element name=“ageInYears” type=“xsd:int”/>
<xsd:element name=“weightInLbs” type=“xsd:float”/>
<xsd:element name=“heightInInches” type=“xsd:float”/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name=“ArrayOfPERSON”>
<xsd:complexContent>
<xsd:restriction base=“soapenc:Array”>
<attribute ref=“soapenc:arrayType” wsdl:arrayType=“typens:PERSON[]”/>
</xsd:restriction>
</xsd:complexContent>
</xsd:complexType>
</schema>
</types>
<message name=“addPersons”>
<part name=“person” type=“typens:ArrayOfPERSON”/>
</message>
<message name=“addPersonResponse”>
<part name=“result” type=“xsd:int”/>
</message>
</definitions>
八、<portType>和<operation>元素
PortType定义了一些抽象的操作。PortType中的operation元素定义了调用PortType中所有方法的语法,每一个operation元素声明了方法的名称、参数(使用<message>元素)和各自的类型(<part>元素要在所有<message>中声明)。
在一篇WSDL文档中可以有几个<PortType>元素,每一个都和一些相关操作放在一起,就和COM和一组操作的接口相似。
在<operation>元素中,可能会有至多一个<input>元素,一个<output>元素,以及一个<fault>元素。三个元素各有一个名字和一个消息属性。
<input>, <output>, <fault>元素属性的名字有何含义呢?它们可以用来区别两个同名操作(重载)。例如,看下面两个C函数:
void foo(int arg);
void foo(string arg);
这种重载在WSDL中可以这样表示:
<?xml version=“1.0” encoding=“UTF-8” ?>
<definitions name=“fooDescription”
targetNamespace=“http://tempuri.org/wsdl/”
xmlns:wsdlns=“http://tempuri.org/wsdl/”
xmlns:typens=“http://tempuri.org/xsd”
xmlns:xsd=“http://www.w3.org/2001/XMLSchema”
xmlns:soap=“http://schemas.xmlsoap.org/wsdl/soap/”
xmlns:stk=“http://schemas.microsoft.com/soap-toolkit/wsdl-extension”
xmlns=“http://schemas.xmlsoap.org/wsdl/”>
<types>
<schema targetNamespace=“http://tempuri.org/xsd”
xmlns=“http://www.w3.org/2001/XMLSchema”
xmlns:SOAP-ENC=“http://schemas.xmlsoap.org/soap/encoding/”
xmlns:wsdl=“http://schemas.xmlsoap.org/wsdl/”
elementFormDefault=“qualified” >
</schema>
</types>
<message name=“foo1”>
<part name=“arg” type=“xsd:int”/>
</message>
<message name=“foo2”>
<part name=“arg” type=“xsd:string”/>
</message>
<portType name=“fooSamplePortType”>
<operation name=“foo” parameterOrder=“arg “ >
<input name=“foo1” message=“wsdlns:foo1”/>
</operation>
<operation name=“foo” parameterOrder=“arg “ >
<input name=“foo2” message=“wsdlns:foo2”/>
</operation>
</portType>
<binding name=“fooSampleBinding” type=“wsdlns:fooSamplePortType”>
<stk:binding preferredEncoding=“UTF-8” />
<soap:binding style=“rpc” transport=“http://schemas.xmlsoap.org/soap/http”/>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo1”/>
<input name=“foo1”>
<soap:body use=“encoded” namespace=http://tempuri.org/message/ encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo2”/>
<input name=“foo2”>
<soap:body use=“encoded” namespace=“http://tempuri.org/message/” encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
</binding>
<service name=“FOOService”>
<port name=“fooSamplePort” binding=“fooSampleBinding”>
<soap:address location=“http://carlos:8080/fooService/foo.asp”/>
</port>
</service>
</definitions>
到目前为止,还没有一种SOAP的实现支持重载。这对基于JAVA的客户端十分重要,因为JAVA服务器使用的接口用到JAVA的重载特性。而对基于COM的客户端,就不那么重要,因为COM是不支持重载的。
九、<binding>和<operation>元素
Binding栏是完整描述协议、序列化和编码的地方,Types, Messages和PortType栏处理抽象的数据内容,而Binding栏是处理数据传输的物理实现。Binding栏把前三部分的抽象定义具体化。
把相关的数据制定和消息声明分开,这意味着同一类型服务的提供者可以把一系列的操作标准化。每个提供者可以提供定制的binding来互相区分。WSDL也有一个重要的结构,使抽象定义可以放在分离的文件中,而不是和Bindings和Services在一起,这样可在不同的服务提供者之间提供标准化的抽象定义,这很有帮助。例如,银行可以用WSDL文档来标准化一些银行的操作。每个银行仍然可以自由的订制下层的协议、串行优化,及编码。
下面是重载的WSDL示例 的Binding栏,重复在此以便讨论:
<binding name=“fooSampleBinding” type=“wsdlns:fooSamplePortType”>
<stk:binding preferredEncoding=“UTF-8” />
<soap:binding style=“rpc” transport=“http://schemas.xmlsoap.org/soap/http”/>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo1”/>
<input name=“foo1”>
<soap:body use=“encoded” namespace=http://tempuri.org/message/ encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
<operation name=“foo”>
<soap:operation soapAction=“http://tempuri.org/action/foo2”/>
<input name=“foo2”>
<soap:body use=“encoded” namespace=“http://tempuri.org/message/” encodingStyle=“http://schemas.xmlsoap.org/soap/encoding/” />
</input>
</operation>
</binding>
<binding>元素已经取了一个名字(本例中”fooSampleBinding”),这样就可以被Services栏的<port>元素引用了。它有一个”type”的属性引用<portType>,本例中就是”wsdlns:fooSamplePortType”。第二行是MSTK2的扩展元素<stk:binding>,它指定了preferredEncoding属性为”UTF-8”。
<soap:binding>元素指定了所使用的风格(”rpc”)和传输方式。Transport属性应用了一个namespace,正是这个namespace指明使用HTTP SOAP协议。
有两个同以”foo”命名的<operation>元素。唯一不同的是它们各自的<input>名字,分别为”foo1”和”foo2”。两个<operation>元素中的<soap:operation>元素有同样的”soapAction”属性,是URI。soapAction属性是SOAP特定的URI,它只是简单的使用于SOAP消息。所产生的SOAP消息有一个SOAPAction头,而URI也仅在<soap:operation>元素里才起作用。soapAction属性在HTTP的binding中是必需的,但在其他非HTTP binding中却不要提供。目前它的使用并不清楚,但它似乎有助于本例中的两个”foo”操作。SOAP 1.1指明soapAction用来确定消息的”意图”。似乎服务器可以在不解析整个消息的情况下就能使用这一属性来发送消息。实际上,它的使用多种多样。<soap:operation>元素也可以包含另一属性,即”style”属性,在有必要冲突<soap:binding>元素指定的风格时可以使用。
<operation>属性可以包含<input>, <output> 和<fault>的元素,它们都对应于PortType栏中的相同元素。只有<input>元素在上例中提供。这三个元素中的每一个可有一个可选的”name”属性,在本例中,我们用这种方法来区分同名操作。在本例的<input>元素中有一个<soap:body>元素,它指定了哪些信息被写进SOAP消息的信息体中。该元素有以下属性:
Use
用于制定数据是”encoded”还是”literal”。”Literal”指结果SOAP消息包含以抽象定义(Types, Messages, 和PortTypes)指定格式存在的数据。”Encoded”指”encodingStyle”属性决定了编码方式。
Namespace
每个SOAP消息体可以有其自己的namespace来防止命名冲突。这一属性制定的URI在结果SOAP消息中逐字使用。
EncodingStyle
对SOAP编码,它应该有以下URI值:
“http://schemas.xmlsoap.org/soap/encoding”
十、文档风格实现
在前几栏中,<soap:binding>元素有一个类型(style)属性,设为”rpc”。此属性设为”document”时会改变传输时消息的串行化。不同于函数签名,现在的消息是文档传输的。在这类binding中,<message>元素定义文档格式,而不是函数签名。作为例子,考虑以下WSDL片段:
<definitions
xmlns:stns=“(SchemaTNS)”
xmlns:wtns=“(WsdlTNS)”
targetNamespace=“(WsdlTNS)”>
<schema targetNamespace=“(SchemaTNS)” elementFormDefault=“qualified”>
<element name=“SimpleElement” type=“xsd:int”/>
<element name=“CompositElement” type=“stns:CompositeType”/>
<complexType name=“CompositeType”>
<all>
<element name='a' type=“xsd:int”/>
<element name='b' type=“xsd:string”/>
</all>
</complexType>
</schema>
<message...>
<part name='p1' type=“stns:CompositeType”/>
<part name='p2' type=“xsd:int”/>
<part name='p3' element=“stns:SimpleElement”/>
<part name='p4' element=“stns:CompositeElement”/>
</message>
…
</definitions>
schema有两个元素:SimpleElement和CompositeElement,还有一个类型声明(CompositeType)。唯一声明的<message>元素有四个部分:p1:Composite型;p2:int型;p3:SimpleElement型;p4:CompositeElement型。以下有一个表,对四种类型的use/type决定的binding作一比较:rpc/literal, document/literal, rpc/encoded, 以及document/encoded。表指明了每种binding的表现。
十一、<service>和<port>元素
service是一套<port>元素。在一一对应形式下,每个<port>元素都和一个location关联。如果同一个<binding>有多个<port>元素与之关联,可以使用额外的URL地址作为替换。
一个WSDL文档中可以有多个<service>元素,而且多个<service>元素十分有用,其中之一就是可以根据目标URL来组织端口。这样,我就可以方便的使用另一个<service>来重定向我的股市查询申请。我的客户端程序仍然工作,因为这种根据协议归类的服务不随服务而变化。多个<service>元素的另一个作用是根据特定的协议划分端口。例如,我可以把所有的HTTP端口放在同一个<service>中,所有的SMTP端口放在另一个<service>里。我的客户可以搜索与它可以处理的协议相匹配的<service>。
<service name=“FOOService”>
<port name=“fooSamplePort” binding=“fooSampleBinding”>
<soap:address location=“http://carlos:8080/fooService/foo.asp”/>
</port>
</service>
在一个WSDL文档中,<service>的name属性用来区分不同的service。因为同一个service中可以有多个端口,它们也有”name”属性。
总结
本文中我描述了WSDL文档关于SOAP方面的最显著的特点。不过应该说明的是WSDL并不仅限于HTTP上的SOAP。WSDL用来描述HTTP-POST、HTTP-GET、SMTP及其他协议时非常清晰。使用了WSDL,SOAP更加容易处理了,无论是开发者还是使用者。我相信WSDL和SOAP一起将会开创网络应用程序世界的新时代。
WSDL的namespace里有一系列的XML元素。下表概述了那些元素、它们的属性和内容。
元素 属性 内容(子元素)
<definitions> name
targetNamespace
xmlns (other namespaces) <types>
<message>
<portType>
<binding>
<service>
<types> (none) <xsd:schema>
<message> Name <part>
<portType> Name <operation>
<binding> name
type <operation>
<service> name <port>
<part> name
type (empty)
<operation> name
parameterOrder <input>
<output>
<fault>
<input> name
message (empty)
<output> name
message (empty)
<fault> name
message (empty)
<port> name
binding <soap:address>
资源:
1. WSDL 1.1
2. SOAP 1.1
3. XML Schema Primer
4. MS SOAP Toolkit Download Site
5. A tool for translating IDL to WSDL
6. Free Web Services resources including a WSDL to VB proxy generator
7. PocketSOAP: SOAP related components, tools & source code
发表评论
-
Axis2 XFire CXF 比较
2010-08-16 10:30 4046CXF最新版本:2.2.2 开源服务框架,可以通过API ... -
配置XFireClientFactoryBean时 设置 lookupServiceOnStartup = false
2010-08-05 16:45 1168<bean id="xxxService& ... -
Web Service描述语言 WSDL 详解(一)
2009-11-04 13:43 1434一、为什么使用WSDL? 像Internet协议之类的标准 ... -
Java调用以WSDL形式发布的web service
2009-11-04 13:40 2085webservice的 发布一般都 ... -
Web Service
2009-11-03 10:31 999一.Axis简介 1. 什么是SOAP ... -
Web service总述
2009-11-03 10:26 704分布式应用程序和浏览 ...
相关推荐
内容概要:本文介绍了如何利用CST软件进行三维超材料的能带计算。首先概述了三维超材料的独特性质及其广泛应用前景,接着简要介绍了CST软件的功能特点。随后详细阐述了能带计算的具体步骤,包括模型建立、材料参数设置、网格划分与求解设置以及最终的计算与结果分析。最后给出了一段Python代码示例,展示了如何处理CST输出的数据并绘制能带图。文章强调了计算机模拟技术对于深入了解超材料电子结构和物理性质的重要性。 适合人群:从事材料科学研究的专业人士,尤其是对三维超材料和电磁场模拟感兴趣的科研工作者和技术人员。 使用场景及目标:适用于希望借助CST软件开展三维超材料能带计算的研究项目,旨在提高对超材料的理解,推动相关领域的技术创新和发展。 其他说明:文中提供的Python代码仅为示例,在实际操作时可根据具体情况进行调整优化。同时,掌握CST软件的基本操作和电磁理论基础知识有助于更好地理解和应用本文内容。
内容概要:本文详细介绍了基于FPGA的永磁同步伺服系统的矢量控制设计,涵盖了从电流环到速度环的关键模块实现。具体包括Clarke和Park变换、PI调节器、AD7606采样、正交编码器反馈以及SVPWM生成等部分。文中提供了详细的Verilog代码片段,展示了各个模块的具体实现方法和技术细节。特别强调了定点数处理、时序设计和跨时钟域处理等方面的技术挑战及其解决方案。 适合人群:具备一定FPGA开发经验和电机控制基础知识的研发人员。 使用场景及目标:适用于希望深入了解FPGA在电机控制应用中的具体实现方式,特别是矢量控制和电流环设计的专业人士。目标是掌握FPGA平台下高效、低延迟的电机控制系统设计方法。 阅读建议:由于涉及大量具体的Verilog代码和硬件设计细节,建议读者在阅读过程中结合实际项目进行实验和调试,以便更好地理解和掌握相关技术。
经典飞机大战游戏是理解实时交互系统设计的绝佳载体。本文将深入剖析现代空战游戏的核心模块,涵盖刚体运动学、弹道轨迹优化、碰撞检测算法等关键技术,揭示二维游戏背后复杂的三维数学建模过程。
scratch少儿编程逻辑思维游戏源码-冰塔.zip
scratch少儿编程逻辑思维游戏源码-弹跳(4).zip
内容概要:本文详细介绍了COMSOL软件中三种常见的焊接热源模型——双椭球热源、高斯旋转体热源和柱状体热源。双椭球热源适用于模拟移动热源(如激光焊、电弧焊),通过调整轴向系数a1和a2来控制热流分布;高斯旋转体热源适合小范围焊接,采用三维高斯函数描述热流密度;柱状体热源则用于深熔焊场景,特点是计算速度快。文中还提供了每种模型的具体代码实现,并强调了调试时需要注意的关键点,如时间步长、网格加密等。此外,作者分享了一些实用技巧,如将热源参数设置为全局变量并利用参数扫描功能提高调试效率。 适合人群:从事焊接工艺仿真、材料加工领域的研究人员和技术人员,以及对COMSOL建模感兴趣的工程技术人员。 使用场景及目标:帮助用户选择合适的热源模型进行焊接模拟,确保模拟结果的准确性;提供具体的代码实现和调试方法,使用户能够快速掌握并应用于实际项目中。 其他说明:文中提到的热源模型不仅限于理论介绍,还包括实际操作中的注意事项和优化建议,有助于提升模拟效果和工作效率。
内容概要:本文介绍了将基于RBF神经网络的PID控制器应用于永磁同步电机(PMSM)转速环控制的方法及其性能优势。传统的PID控制器在面对非线性和时变系统时存在参数整定困难的问题,而引入RBF神经网络可以实现实时在线调参,提高系统的灵活性和鲁棒性。文中详细描述了Simulink模型的设计,特别是Matlab s-function模块中RBF神经网络的具体实现,包括高斯函数激活和带惯性的权值更新机制。实验结果显示,在转速突变情况下,改进后的控制器能够迅速稳定系统,超调量控制在2%以内,调节时间较传统方法缩短约40%,并且在负载变化时表现出色,无需重新整定参数。 适合人群:从事电机控制系统研究和开发的技术人员,尤其是对PID控制器优化感兴趣的工程师。 使用场景及目标:适用于需要提升PMSM转速环控制精度和响应速度的应用场合,如工业自动化设备、机器人等领域。目标是通过引入智能算法解决传统PID控制器参数整定难题,提高系统性能。 阅读建议:关注RBF神经网络与PID控制器结合的具体实现细节,特别是在Matlab s-function模块中的编码技巧以及参数调整策略。同时,注意学习率的选择和动量项的作用,这对于实际应用至关重要。
scratch少儿编程逻辑思维游戏源码-GTA 6.zip
scratch少儿编程逻辑思维游戏源码-仓鼠跑酷.zip
scratch少儿编程逻辑思维游戏源码-超级麦克世界.zip
scratch少儿编程逻辑思维游戏源码-400年.zip
少儿编程scratch项目源代码文件案例素材-气球足球.zip
少儿编程scratch项目源代码文件案例素材-沙漠迷城.zip
scratch少儿编程逻辑思维游戏源码-比谁高.zip
少儿编程scratch项目源代码文件案例素材-乾坤大挪移.zip
scratch少儿编程逻辑思维游戏源码-菜鸟跳跃.zip
内容概要:本文档详细介绍了C++语言的基础知识、高级特性及其应用。首先,文档回顾了C++对C语言的扩展,包括面向对象编程的支持、增强的语法特性(如命名空间、引用、常量处理等)。接着,深入探讨了类和对象的使用,涵盖构造函数、析构函数、拷贝构造函数、深浅拷贝等重要概念。文档还讲解了单例模式的设计与实现、C++面向对象模型的核心要素(如this指针、静态成员、友元函数)、继承与派生的关系及其实现细节、多态性的原理与应用。此外,文档详细介绍了C++的模板机制、类型转换、异常处理机制、输入输出流操作、STL(标准模板库)的容器和算法等内容。每个部分都通过具体的代码示例和解释,帮助读者理解和掌握C++的关键特性和最佳实践。 适合人群:具备一定编程基础,尤其是熟悉C语言的开发者;希望深入了解C++语言特性和面向对象编程思想的程序员;从事C++开发工作的工程师和技术爱好者。 使用场景及目标:①掌握C++语言的核心概念和高级特性;②理解并能够应用面向对象编程的基本原则和模式;③学习如何使用STL容器和算法优化代码性能;④提升C++程序的健壮性和可维护性,特别是在处理复杂数据结构和算法时;⑤掌握异常处理和类型转换的最佳实践,确保程序的稳定性和安全性。 其他说明:本文档不仅提供了理论知识,还结合了大量实例代码,便于读者边学边练。对于每一个知识点,文档都力求做到详尽解释,确保读者能够透彻理解并灵活运用。文档内容全面覆盖了C++编程的各个方面,从基础语法到高级特性,适合不同层次的学习者逐步深入学习。
内容概要:本文详细探讨了电气铁路柔性过分相技术中的60°换相波形稳定问题。首先介绍了柔性过分相的基本概念及其重要性,接着重点讨论了60°换相波形稳定对系统运行效率和稳定性的影响。文中还阐述了实现换相波形稳定的多种方法,如先进控制算法、实时监测设备以及滤波器的应用。最后,通过引用相关文献和实例,进一步验证了换相波形稳定的重要性和可行性。 适合人群:从事电气铁路系统设计、维护的技术人员,以及对该领域感兴趣的科研人员。 使用场景及目标:适用于希望深入了解电气铁路柔性过分相技术的专业人士,旨在帮助他们掌握60°换相波形稳定的相关理论和技术手段,提升系统性能。 其他说明:文章结合了理论分析与实际案例,提供了丰富的参考资料,有助于读者全面理解并应用于实际工作中。
scratch少儿编程逻辑思维游戏源码-发动.zip
少儿编程scratch项目源代码文件案例素材-色彩跳跃 2.5D.zip