WebService——SOAP详解

06-01 663阅读

目录

  • SOAP
    • 1、概述
    • 2、语法
      • 2.1、组成部分
      • 2.2、语法规则
      • 2.3、基本结构
      • 3、Envelope元素
        • 3.1、xmlns:soap 命名空间
        • 3.2、encodingStyle 属性
        • 4、Header元素
          • 4.1、mustUnderstand 属性
          • 4.2、actor 属性
          • 4.3、encodingStyle 属性
          • 5、Body元素
          • 6、Fault元素
          • 7、SOAP HTTP Binding
            • 7.1、Content-Type
            • 7.2、Content-Length
            • 8、实例

              SOAP

              1、概述

              SOAP即(Simple Object Access Protocol)简单对象访问协议是交换数据的一种协议规范,是一种轻量的、简单的、基于XML(标准通用标记语言下的一个子集)的协议,它被设计成在WEB上交换结构化的和固化的信息。

              SOAP 可以和现存的许多因特网协议和格式结合使用,包括超文本传输协议(HTTP),简单邮件传输协议(SMTP),多用途网际邮件扩充协议(MIME)。它还支持从消息系统到远程过程调用(RPC)等大量的应用程序。SOAP使用基于XML的数据结构和超文本传输协议(HTTP)的组合定义了一个标准的方法来使用Internet上各种不同操作环境中的分布式对象。

              2、语法

              2.1、组成部分

              一条 SOAP 消息就是一个普通的 XML 文档,包含下列元素:

              • 必需的Envelope元素,可把此 XML 文档标识为一条 SOAP 消息
              • 可选的Header元素,包含头部信息
              • 必需的Body元素,包含所有的调用和响应信息
              • 可选的Fault元素,提供有关在处理此消息所发生错误的信息

                所有以上的元素均被声明于针对 SOAP 封装的默认命名空间中:http://www.w3.org/2001/12/soap-envelope。

                以及针对 SOAP 编码和数据类型的默认命名空间:

                http://www.w3.org/2001/12/soap-encoding。

                2.2、语法规则

                • SOAP 消息必须用 XML 来编码
                • SOAP 消息必须使用 SOAP Envelope 命名空间
                • SOAP 消息必须使用 SOAP Encoding 命名空间
                • SOAP 消息不能包含 DTD 引用
                • SOAP 消息不能包含 XML 处理指令

                  2.3、基本结构

                  SOAP消息的基本结构如下:

                  
                  
                  ...
                  
                  
                  ...
                    
                    ...
                    
                  
                  
                  

                  3、Envelope元素

                  SOAP 的 Envelope 元素是 SOAP 消息的根元素。它可把 XML 文档定义为 SOAP 消息。

                  
                    ...
                    Message information goes here
                    ...
                  
                  

                  3.1、xmlns:soap 命名空间

                  SOAP 消息必须拥有与命名空间 "http://www.w3.org/2001/12/soap-envelope" 相关联的一个 Envelope 元素。如果使用了不同的命名空间,应用程序会发生错误,并抛弃此消息。

                  3.2、encodingStyle 属性

                  SOAP 的 encodingStyle 属性用于定义在文档中使用的数据类型。此属性可出现在任何 SOAP 元素中,并会被应用到元素的内容及元素的所有子元素上。SOAP 消息没有默认的编码方式。

                  语法:

                  soap:encodingStyle="URI"
                  

                  实例:

                  
                    ...
                    Message information goes here
                    ...
                  
                  

                  4、Header元素

                  可选的 SOAP Header 元素可包含有关 SOAP 消息的应用程序专用信息(比如认证、支付等)。如果 Header 元素被提供,则它必须是 Envelope 元素的第一个子元素。

                  注意: 所有 Header 元素的直接子元素必须是合格的命名空间。

                  
                  
                    234
                    
                  
                  ...
                  ...
                  
                  

                  上面的例子包含了一个带有一个 “Trans” 元素的头部,它的值是 234,此元素的 “mustUnderstand” 属性的值是 “1”。

                  WebService——SOAP详解
                  (图片来源网络,侵删)

                  SOAP 在默认的命名空间中 (“http://www.w3.org/2001/12/soap-envelope”) 定义了三个属性。

                  这三个属性是:actor、 mustUnderstand 以及encodingStyle。这些被定义在 SOAP 头部的属性可定义容器如何对 SOAP 消息进行处理。

                  WebService——SOAP详解
                  (图片来源网络,侵删)

                  4.1、mustUnderstand 属性

                  SOAP 的 mustUnderstand 属性可用于标识标题项对于要对其进行处理的接收者来说是强制的还是可选的。

                  假如向 Header 元素的某个子元素添加了"mustUnderstand="1",则它可指示处理此头部的接收者必须认可此元素。假如此接收者无法认可此元素,则在处理此头部时必须失效。

                  WebService——SOAP详解
                  (图片来源网络,侵删)

                  语法:

                  soap:mustUnderstand="0|1"
                  

                  实例:

                  
                  
                    234
                    
                  
                  ...
                  ...
                  
                  

                  4.2、actor 属性

                  通过沿着消息路径经过不同的端点,SOAP 消息可从某个发送者传播到某个接收者。并非 SOAP 消息的所有部分均打算传送到 SOAP 消息的最终端点,不过,另一个方面,也许打算传送给消息路径上的一个或多个端点。

                  SOAP 的 actor 属性可被用于将 Header 元素寻址到一个特定的端点。

                  语法:

                  soap:actor="URI"
                  

                  实例:

                  
                  
                    234
                    
                  
                  ...
                  ...
                  
                  

                  4.3、encodingStyle 属性

                  SOAP 的 encodingStyle 属性用于定义在文档中使用的数据类型。此属性可出现在任何 SOAP 元素中,并会被应用到元素的内容及元素的所有子元素上。

                  SOAP 消息没有默认的编码方式。

                  语法:

                  soap:encodingStyle="URI"
                  

                  5、Body元素

                  SOAP Body 元素可包含打算传送到消息最终端点的实际 SOAP 消息。SOAP Body 元素的直接子元素可以是合格的命名空间。

                  
                  
                    
                      Apples
                    
                  
                  
                  

                  上面的例子请求苹果的价格。请注意,上面的 m:GetPrice 和 Item 元素是应用程序专用的元素。它们并不是 SOAP 标准的一部分。

                  而一个 SOAP 响应应该类似这样:

                  
                  
                    
                      1.90
                    
                  
                  
                  

                  6、Fault元素

                  SOAP Fault 元素用于指示错误消息。如果已提供了 Fault 元素,则它必须是 Body 元素的子元素。在一条 SOAP 消息中,Fault 元素只能出现一次。

                  SOAP 的 Fault 元素拥有下列子元素:

                  • :供识别故障的代码
                  • :可供人阅读的有关故障的说明
                  • :有关是谁引发的故障的信息
                  • :存留涉及Body元素的应用程序专用错误信息

                    SOAP Fault代码:

                    • VersionMismatch:SOAP Envelope 元素的无效命名空间被发现
                    • MustUnderstand:Header 元素的一个直接子元素(带有设置为 “1” 的 mustUnderstand 属性)无法被理解。
                    • Client:消息被不正确地构成,或包含了不正确的信息。
                    • Server:服务器有问题,因此无法处理进行下去。

                      7、SOAP HTTP Binding

                      指的是遵守 SOAP 编码规则的 HTTP 请求/响应。

                      HTTP + XML = SOAP:

                      SOAP 请求可能是 HTTP POST 或 HTTP GET 请求。

                      HTTP POST 请求规定至少两个 HTTP 头:

                      • Content-Type
                      • Content-Length

                        7.1、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
                        

                        7.2、Content-Length

                        SOAP 的请求和响应的 Content-Length 头规定请求或响应主体的字节数。

                        语法:

                        Content-Length: bytes
                        

                        实例:

                        POST /item HTTP/1.1
                        Content-Type: application/soap+xml; charset=utf-8
                        Content-Length: 250
                        

                        8、实例

                        在下面的例子中,一个 GetStockPrice 请求被发送到了服务器。此请求有一个 StockName 参数,而在响应中则会返回一个 Price 参数。此功能的命名空间被定义在此地址中: “http://www.example.org/stock”

                        SOAP请求:

                        POST /InStock HTTP/1.1
                        Host: www.example.org
                        Content-Type: application/soap+xml; charset=utf-8
                        Content-Length: nnn
                        
                        
                        
                          
                            IBM
                          
                        
                        
                        

                        SOAP响应:

                        HTTP/1.1 200 OK
                        Content-Type: application/soap+xml; charset=utf-8
                        Content-Length: nnn
                        
                        
                        
                          
                            34.5
                          
                        
                        
                        
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

相关阅读

目录[+]

取消
微信二维码
微信二维码
支付宝二维码