- SoapUI 教程
- SoapUI - 首页
- SOAP 基础
- SOAP - 简介
- SOAP - 消息
- SOAP - REST 是什么?
- SoapUI 基础
- SoapUI - 简介
- SoapUI - 功能
- SoapUI - NG Pro
- SoapUI - 安装与配置
- SoapUI - WSDL
- SoapUI - 项目
- SoapUI - 测试套件
- SoapUI - 测试用例
- SoapUI - 测试步骤
- SoapUI - 请求与响应
- SoapUI - 属性
- SoapUI - 属性传递
- SoapUI - 日志面板
- SoapUI - 断言
- SoapUI - 故障排除
- SoapUI - 性能测试
- SoapUI - 负载测试
- SoapUI - RESTful Web 服务
- SoapUI - JDBC 连接
- SoapUI - JDBC 属性
- SoapUI - JDBC 断言
- SoapUI 有用资源
- SoapUI - 快速指南
- SoapUI - 有用资源
- SoapUI - 讨论
SoapUI - WSDL
WSDL 代表 Web 服务描述语言 (Web Services Description Language)。它是一种描述 Web 服务的标准格式。WSDL 由微软和 IBM 共同开发。WSDL 的发音为“wiz-dull”,拼写为“W-S-D-L”。
WSDL ─ 简史
2001 年 3 月,Ariba、IBM 和微软将 WSDL 1.1 提交给 W3C 作为关于描述 W3C XML 活动中 XML 协议服务的 W3C 说明。
WSDL 1.1 未获得万维网联盟 (W3C) 的认可,但它刚刚发布了 2.0 版的草案,该版本将成为建议(正式标准),因此将获得 W3C 的认可。
WSDL ─ 注意事项
WSDL 是一种基于 XML 的协议,用于在分散和分布式环境中进行信息交换。WSDL 的其他一些功能如下:
WSDL 定义描述了如何访问 Web 服务以及它将执行哪些操作。
它是一种用于描述如何与基于 XML 的服务交互的语言。
它是通用描述、发现和集成 (UDDI) 的组成部分,UDDI 是一个基于 XML 的全球业务注册中心。
WSDL 是 UDDI 使用的语言。
WSDL 用法
WSDL 通常与 SOAP 和 XML Schema 结合使用,以通过 Internet 提供 Web 服务。连接到 Web 服务的客户端程序可以读取 WSDL 以确定服务器上可用的功能。任何使用的特殊数据类型都以 XML Schema 的形式嵌入到 WSDL 文件中。然后,客户端可以使用 SOAP 来实际调用 WSDL 中列出的功能之一。
理解 WSDL
WSDL 将 Web 服务分解为三个特定且可识别的元素,这些元素一旦定义就可以组合或重复使用。
WSDL 的三个主要元素可以分别定义:
- 类型
- 操作
- 绑定
WSDL 文档包含各种元素,但它们包含在这三个主要元素中,这些元素可以作为单独的文档开发,然后可以组合或重复使用以形成完整的 WSDL 文件。
在本教程中,我们遵循 CurrencyConverter WSDL:http://www.webservicex.net
格式和元素
CurrencyConverter WSDL 看起来如下:
WSDL ─ 端口类型
<portType>
元素将多个消息元素组合起来形成完整的单向或往返操作。例如,<portType>
可以将一个请求消息和一个响应消息组合成单个请求/响应操作。这最常用于 SOAP 服务。portType 可以定义多个操作。
示例
- portType 元素定义了一个名为 ConversionRate 的单个操作。
- 该操作包含单个输入消息 ConversionRateHttpPostIn。
- 输出消息的操作为 ConversionRateHttpPostOut。
操作模式
WSDL 支持四种基本的操作模式:
单向
服务接收消息。因此,操作只有一个输入元素。单向操作的语法为:
<wsdl:definitions .... > <wsdl:portType .... > * <wsdl:operation name = "nmtoken"> <wsdl:input name = "nmtoken"? message = "qname"/> </wsdl:operation> </wsdl:portType > </wsdl:definitions>
请求 ─ 响应
服务接收消息并发送响应。因此,操作包含一个输入元素,后跟一个输出元素。为了封装错误,还可以指定可选的错误元素。请求-响应操作的语法为:
<wsdl:definitions .... > <wsdl:portType .... > * <wsdl:operation name = "nmtoken" parameterOrder = "nmtokens"> <wsdl:input name = "nmtoken"? message = "qname"/> <wsdl:output name = "nmtoken"? message = "qname"/> <wsdl:fault name = "nmtoken" message = "qname"/>* </wsdl:operation> </wsdl:portType > </wsdl:definitions>
请求 ─ 响应
服务发送消息并接收响应。因此,操作包含一个输出元素,后跟一个输入元素。为了封装错误,还可以指定可选的错误元素。请求-响应操作的语法为:
<wsdl:definitions .... > <wsdl:portType .... > * <wsdl:operation name = "nmtoken" parameterOrder = "nmtokens"> <wsdl:output name = "nmtoken"? message = "qname"/> <wsdl:input name = "nmtoken"? message = "qname"/> <wsdl:fault name = "nmtoken" message = "qname"/>* </wsdl:operation> </wsdl:portType > </wsdl:definitions>
通知
服务发送消息。因此,操作只有一个输出元素。以下是通知操作的语法:
<wsdl:definitions .... > <wsdl:portType .... > * <wsdl:operation name = "nmtoken"> <wsdl:output name = "nmtoken"? message = "qname"/> </wsdl:operation> </wsdl:portType > </wsdl:definitions>
WSDL ─ 绑定和服务
<binding>
元素提供有关portType 操作如何实际通过网络传输的具体详细信息。
绑定可以通过多种传输方式提供,包括 HTTP GET、HTTP POST 或 SOAP。
绑定提供有关使用哪个协议来传输 portType 操作的具体信息。
绑定提供服务所在位置的信息。
对于 SOAP 协议,绑定为
<soap:binding>
,传输是在 HTTP 协议之上的 SOAP 消息。您可以为单个 portType 指定多个绑定。
服务
<service>
元素定义 Web 服务支持的端口。对于每个支持的协议,都有一个端口元素。service 元素是端口的集合。
Web 服务客户端可以从 service 元素中了解以下信息:
- 访问服务的位置;
- 通过哪个端口访问 Web 服务;以及
- 通信消息是如何定义的。
service 元素包含一个 documentation 元素,用于提供人类可读的文档。
<wsdl:service name = "CurrencyConvertor"> <wsdl:port name = "CurrencyConvertorSoap" binding = "tns:CurrencyConvertorSoap"> <soap:address location = "http://www.webservicex.net/CurrencyConvertor.asmx" /> </wsdl:port> <wsdl:port name = "CurrencyConvertorSoap12"binding = "tns:CurrencyConvertorSoap12> <soap12:address location = "http://www.webservicex.net/CurrencyConvertor.asmx" /> </wsdl:port> <wsdl:port name = "CurrencyConvertorHttpGet" binding = "tns:CurrencyConvertorHttpGet"> <http:address location = "http://www.webservicex.net/CurrencyConvertor.asmx" /> </wsdl:port> <wsdl:portname = "CurrencyConvertorHttpPost"binding = "tns:CurrencyConvertorHttpPost"> <http:address location = "http://www.webservicex.net/CurrencyConvertor.asmx" /> </wsdl:port> </wsdl:service>