Soap教程
encodingStyle属性
Soap中的encodingStyle属性用于定义在文档中使用的数据类型。该属性可以出现在任何的Soap元素中,并会被应用到元素的内容及使用在元素的所有子元素上。
Soap消息没有默认的编码方式。
语法:soap:encodingStyle = "URI"
SOAP Body元素
SOAP Body元素是必须的,可以包含要传送到消息最终端点的实际SOAP消息。
SOAP Body元素的直接子元素可以是合格的命名空间。
实例:
<?xml version="1.0" ?>
<soap:Envelope xmlns:soap="http://www.w3.org/2001/12/soap-envelope" soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding">
<soap:Body>
<m:GetPrice xmlns:m="//www.w3cschool.cn/prices">
<m:Item>Apples</m:Item>
</m:GetPrice>
</soap:Body>
</soap:Envelope>
上面的例子请求苹果的价格。请注意,上面的m:GetPrice和Item元素是应用程序专有的元素。它们并不是SOAP标准的一部分。
而一个SOAP响应应该类似这样:
<?xml version="1.0" ?>
<soap:Envelope xmlns:soap="http://www.w3.org/2001/12/soap-envelope" soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding">
<soap:Body>
<m:GetPriceResponse xmlns:m="//www.w3cschool.cn/prices">
<m:Price>1.90</m:Price>
</m:GetPriceResponse>
</soap:Body>
</soap:Envelope>
SOAP Fault 元素
SOAP Fault是SOAP Body内部的一个元素,用于指示错误消息
SOAP Fault用于留存SOAP消息出现的错误和状态的消息
可选的SOAP Faul元素用于指示错误消息。
如果提供了Fault元素,则它必须是Body元素的子元素。在SOAP消息中,Fault元素只能出现一次。
SOAP中的Fault元素拥有下列子元素:
<faultcode> : 供识别故障的代码
<faultstring> : 可供人阅读的有关故障的说明
<faultactor> : 有关是谁引发故障的信息
<detail> : 存留涉及Body元素的应用程序专用错误信息
SOAP Fault代码
在下面定义的faultcode值必须用于描述错误时的faultcode元素中:
VersionMismatch: SOAP Envelope元素的无效命名空间被发现
MustUnderstand: Header元素的一个直接子元素(带有设置为“1”的mustUnderstand属性)无法被理解
Client: 消息被不正确地构成,或包含了不正确的信息
Server: 服务器有问题,因此无法处理进行下去
SOAP HTTP Binding
SOAP HTTP协议:SOAP采用HTTP作为底层通讯协议。
HTTP协议
HTTP在TCP/IP之上进行通信。HTTP客户机可通过TCP连接HTTP服务器。在建立连接之后,客户机可向服务器发送HTTP请求消息:
Post /item HTTP/1.1
Host: 189.123.255.239
Content-Type: text/plain
Content-Length: 200
随后服务器会处理此请求,然后向客户机发送一个HTTP响应。此响应包含了可指示请求状态的状态代码。
200 OK
Content-Type: text/plain
Content-Length: 200
在上面的例子中,服务器返回了一个200的状态代码。这是HTTP的标准成功代码。
假如服务器无法对请求进行解码,它可能会返回类似这样的信息:
400 Bad Request
Content-Length: 0
SOAP HTTP Binding
SOAP方法指的是遵守SOAP编码规则的HTTP请求/响应。
HTTP+XML = SOAP
SOAP请求可能是HTTP POST或HTTP GET请求。
HTTP POST请求规定至少两个HTTP头:Content-Type和Content-Length.
Content-Type:
SOAP的请求和响应中的Content-Type头可定义消息的MIME类型,以及用于请求和响应的XML主体的字符编码(可选)
语法:Content-Type: MIMEType; charset=character-encoding
实例:
POST /item HTTP/1.1
Content-Type: application/soap+xml; charset=utf-8
Content-Length:
SOAP的请求和响应的Content-Length头规定请求和响应主体的字节数
语法:Content-Length: bytes
实例:
POST /item HTTP/1.1
Content-Type: application/soap+xml; charset=utf-8
Content-Length: 250