博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php学习之路:WSDL详细解释(两)
阅读量:6585 次
发布时间:2019-06-24

本文共 2457 字,大约阅读时间需要 8 分钟。

3.定义服务使用的逻辑消息

当服务的操作被调用时。服务被定义为消息交换。在wsdl文档中,这些消息被定义message元素。

这些消息由称之为part元素的部分组成。

一个服务的操作,通过指定逻辑消息的方式来定义。当操作被调用时,逻辑消息被交换。(也就是说。逻辑消息代表了服务的操作)这些逻辑消息,将在网络上传输的数据定义为xml文档。他包括了全部的參数,这些參数是方法调用的一部分。

(也就是说。逻辑消息里的參数,是操作相应方法的參数集合)

消息和參数列表:每个被服务暴露的操作能且仅能有一个输入消息和一个输出消息。

输入消息定义当操作被调用时。服务接受的全部消息。输出消息定义的是。当操作完毕时服务返回的全部消息。fault消息定义的是服务返回错误时的数据。

另外,每一个操作能够有一定数量的fault消息。

这个fault消息定义了当服务错误发生时返回的数据。这些消息通常有一个部分。该部分提供足够的信息来让消费者知道错误是什么。

消息设计用于集成固有系统:假设你将已经存在的应用程序定义为一个服务。你必须确保方法(实现操作的方法)中使用到的每一个參数都可以在消息中找到相应。你必须确保返回值也在操作的输出消息中。

定义你的消息的一个方法是:RPC风格。当使用RPC风格时,你使用给每一个在參数列表中的參数定义一个part。每一个消息part是基于在types中顶一个的type。

你的输入消息为每一个输入參数相应一个part,相同输出消息为每一个输出參数相应一个part。

另外添加个part来相应返回值。假设一个參数既是输入,又是输出。那么它即作为输入又作为输出消息列出来。

RPC风格的消息定义是当服务使能存量系统时实用。

它使用类似于TIBCO或者CORBA的模式传输。

这些系统环绕着过程和方法来设计。正是因为这样,他们是最easy使用消息来建模。

RPC风格也是服务和应用程序之间的映射清晰化。

为SOAP服务设计消息:当RPC风格用于建模存量系统,可是服务协会强烈地喜欢包装文档风格。

在包装文档风格中,每一个消息有一个part。

这个消息的part參考了一个包装元素。该元素定义在types元素中。包装元素有例如以下特性:

  • 他是一个包括一系列元素的复合类型
  • 假设是一个输入消息的包装器,则:它的每一个元素相应一个输入參数;他的名字,他的名字与相关的操作名同样。
  • 假设是一个输出消息的包装器。则:它的每一个元素相应输入參数,也相应输出參数。它的第一个元素代表了方法返回值。

    他的名字将通过添加Response到与之想关联的包装器的操作的名字上。

消息命名:每一个消息都在其命名空间中有唯一名字,建议使用以下的命名规则:

  • 消息应该被单一操作使用
  • 输入消息名是在操作名后添加Request
  • 输出消息名是在操作名后添加Response
  • 错误消息名是在错误原因后加fault

消息部件:消息部件是逻辑消息最经常使用的单元。每一个part被定义,用part元素。而且通过name属性,用type属性或element属性来指定数据类型。

消息同意重用part名。对于一个实例来说,假设一个方法有一个參数:foo,他被应用或者通过in/out传递,他可以作为一个Part存在于请求或者应答消息中。例如以下例:

<message name="fooRequest">

  <part name="foo" type="xsd:int"/>
<message>
<message name="fooReply">
  <part name="foo" type="xsd:int"/>
<message>

样例:如果你有一个server存储了个人信息而且提供一个方法,该方法换回雇员的数据,基于雇员ID.。

该方法例如以下:

personalInfo lookup(long empId)

被映射到RPC风格的WSDL例如以下

<message name="personalLookupRequest">

  <part name="empId" type="xsd:int"/>
<message/>
<message name="personalLookupResponse>
  <part name="return" element="xsd1:personalInfo"/>
<message/>

映射到包装风格例如以下:

<types>

  <schema ...>
  ...
  <element name="personalLookup">
    <complexType>
      <sequence>
        <element name="empID" type="xsd:int" />
      </sequence>
    </complexType>
  </element>
  <element name="personalLookupResponse">
    <complexType>
      <sequence>
        <element name="return" type="personalInfo" />
      </sequence>
    </complexType>
  </element>
  </schema>
</types>
<message name="personalLookupRequest">
  <part name="empId" element="xsd1:personalLookup"/>
<message/>
<message name="personalLookupResponse>
  <part name="return" element="xsd1:personalLookupResponse"/>
<message/>

版权声明:本文博客原创文章。博客,未经同意,不得转载。

本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4709144.html,如需转载请自行联系原作者

你可能感兴趣的文章
移动端iphone按下a链接背景颜色会变灰
查看>>
如何识别 MacBook Pro 机型
查看>>
javascript 图标分析工具
查看>>
深入分析Docker镜像原理
查看>>
从结构struct谈到类class(基于C++实现)
查看>>
Python3环境配置
查看>>
阿里云负载均衡服务
查看>>
小命令 sysdig
查看>>
IT十八掌作业_java基础第五天_静态代码块、类的继承和接口
查看>>
流程控制-for序列、流程控制-for字典
查看>>
Easy APNs Provider的使用
查看>>
搭建mysql集群
查看>>
Gson工具包使用
查看>>
有一个系统修复处于挂起状态,需要重新启动才能完成该修复
查看>>
Ubuntu上安装bind9
查看>>
访问共享提示“服务器存储空间不足,无法处理此命令。”
查看>>
第七章 虚拟化 虚拟机备份 Veeam backup &Replication
查看>>
路由器与交换机的密码恢复
查看>>
Cisco路由器上的IPSec协议(站点到站点的×××)
查看>>
Linux Python详细安装、升级指南
查看>>