`

一个完整的WSDL文档及各标签详解

阅读更多

<?xml version="1.0" encoding="UTF8" ?>

<wsdl:definitions targetNamespace="http://www.57market.com.cn/HelloService" 
    xmlns:soapenc12="http://www.w3.org/2003/05/soapencoding" 
    xmlns:tns="http://www.57market.com.cn/HelloService" 
    xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" 
    xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
    xmlns:soap11="http://schemas.xmlsoap.org/soap/envelope/" 
    xmlns:wsdlsoap="http://schemas.xmlsoap.org/wsdl/soap/" 
    xmlns:soapenc11="http://schemas.xmlsoap.org/soap/encoding/" 
    xmlns:soap12="http://www.w3.org/2003/05/soapenvelope">

 


/**
 * types元素,定义了交换信息的数据格式。
 * 为了实现最大的互操作性(interoperability)和平台中立性(neutrality),
 * WSDL选用XML Schema DataTypes简称XSD作为标准类型系统,并将它作为固有类型系统。
 *
 * 下面是数据定义部分,该部分定义了两个元素,一个是sayHello,一个是sayHelloResponse:
 * sayHello:定义了一个复杂类型,仅仅包含一个简单的字符串,将来用来描述操作的参入传入部分;
 * sayHelloResponse:定义了一个复杂类型,仅仅包含一个简单的字符串,将来用来描述操作的返回值;
 */


<wsdl:types>

    <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
                attributeFormDefault="qualified" 
                elementFormDefault="qualified" 
                targetNamespace="http://www.57market.com.cn/HelloService">
                

        <xsd:element name="sayHello">
            <xsd:complexType>
                <xsd:sequence>
                    <xsd:element maxOccurs="1" minOccurs="1" name="in0" nillable="true" type="xsd:string" />
                </xsd:sequence>
            </xsd:complexType>
        </xsd:element>


        <xsd:element name="sayHelloResponse">
            <xsd:complexType>
                <xsd:sequence>
                    <xsd:element maxOccurs="1" minOccurs="1" name="out" nillable="true" type="xsd:string" />
                </xsd:sequence>
            </xsd:complexType>
        </xsd:element>

 
    </xsd:schema>
  </wsdl:types>

 

/**
 * message元素是交换信息的抽象定义。
 * 需要分别定义用于作为输入参数的消息和输出参数的消息。
 *
 * 定义了两个消息 sayHelloRequest 和 sayHelloResponse:
 * sayHelloRequest:sayHello操作的请求消息格式。由一个消息片断(part)组成。
 * 片段的名字为 parameters, 片段的元素是我们前面定义的types中的元素;
 * sayHelloResponse:sayHello操作的响应消息格式。由一个消息片断(part)组成。
 * 片段的名字为 parameters, 片段的元素是我们前面定义的types中的元素;
 *
 * 如果采用RPC样式的消息传递,只需要将文档中的element元素应以修改为type即可。
 *
 * - message:用來定義消息的結構
 * - part:指定引用types中定義的標籤片斷
 *
 */

<wsdl:message name="sayHelloRequest">
     <wsdl:part name="parameters" element="tns:sayHello" />
</wsdl:message>

<wsdl:message name="sayHelloResponse">
     <wsdl:part name="parameters" element="tns:sayHelloResponse" />
</wsdl:message>

 

/**

 * portType元素中定义了Web服务的操作。一些抽象操作的集合。
 * 操作定义了输入和输出数据流中可以出现的XML消息。
 * 每个操作关联一个输入消息和一个输出消息。

 * 这里包含一个操作(operation):sayHello方法,
 * 同时包含input和output表明该操作是一个 请求/响应模式,
 * 
 * input请求的消息体是前面定义的 sayHelloRequest。
 * output响应的消息体是前面定义的 sayHelloResponse。

 *  - portType:用來定義服務端的SEI
 *  - operation:用來指定SEI中的處理請求的方法
 *  - input:指定客戶端應用傳過來的數據,會引用上面的而定義的message
 *  - output:指定服務端返回給客戶端的數據,會引用上面的而定義的message
 */

<wsdl:portType name="HelloServicePortType">

    <wsdl:operation name="sayHello">
        <wsdl:input name="sayHelloRequest" message="tns:sayHelloRequest" />
        <wsdl:output name="sayHelloResponse" message="tns:sayHelloResponse" />
    </wsdl:operation>

</wsdl:portType>

 

/**
 * binding 元素描述特定服务接口的协议、数据格式、安全性和其它属性。
 * 针对operation和portType中使用的message指定实际的协议和数据格式规范。
 *
 * binding:用于定义SEI的实现类
 *  - type:引用上面的 portType
 *  - style:document 绑定的数据是一个document(XML)
 *  - operation:用来定义实现的方法
 *  - input: 指定客户端应传过来的数据
 *  - output:指定服务器端返回客户端的数据
 *  - literal:文本数据
 */

<wsdl:binding name="HelloServiceHttpBinding" type="tns:HelloServicePortType">

        <wsdlsoap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>

        <wsdl:operation name="sayHello">
            <wsdlsoap:operation soapAction="" />
            <wsdl:input name="sayHelloRequest">
                <wsdlsoap:body use="literal" />
            </wsdl:input>
            <wsdl:output name="sayHelloResponse">
                <wsdlsoap:body use="literal" />
            </wsdl:output>
        </wsdl:operation>

</wsdl:binding>

 

 

/**
 * service元素包含一组port元素。
 *
 * port将端点与来自服务接口定义的 binding 元素关联起来。
 * port指定一个绑定的地址,这样定义一个通信的终端。
 *
 * - service:一個webservice的容器
 * - name:它用以指定一個服務器端處理請求的入口(就是SEI的實現)
 * - binding:引用上面定义的 binding
 * - address:当前 webservice 的请求地址
 *
 */

<wsdl:service name="HelloService">

    <wsdl:port name="HelloServiceHttpPort" binding="tns:HelloServiceHttpBinding">
        <soap:address location="http://localhost:8080/xfire/services/HelloService" />
    </wsdl:port>

</wsdl:service>

 


</wsdl:definitions>









WSDL文档可以分为两部分。
顶部分由抽象定义组成,而底部分则由具体描述组成。
抽象部分以独立于平台和语言的方式定义SOAP消息,它们并不包含任何随机器或语言而变的元素。


1、抽象定义(接口)

types     - 独立与机器和语言的类型定义
messages  - 包括函数参数(输入与输出分开)或文档描述
portTypes - 引用消息部分中消息定义来描述函数签名(操作名、输入参数、输出参数)


2、具体定义(实现类)

bindings - PortTypes部分的每一操作在此绑定实现
services - 确定每一绑定的端口地址



问题:
如何发送 SOAP 消息?
SOAP 消息的结构/构成?














http://www.cnblogs.com/ChrisMurphy/p/5224314.html

http://staff.ustc.edu.cn/~shizhu/DotNet/WSDLxj.htm






-
分享到:
评论

相关推荐

    Web Service描述语言 WSDL 详解.pdf

    WSDL文档提供了一种标准的方式来定义网络服务的接口,即服务能够接收哪些请求、返回哪些响应以及这些请求和响应的结构。它是实现服务导向架构(SOA)的关键组件之一,特别是在基于SOAP的Web服务中。 ### WSDL的重要...

    wsdl教程标签解析

    以下是一个简单的WSDL文档片段,展示了如何定义一个服务操作及其输入和输出消息: ```xml &lt;!-- 这里将定义具体的消息格式和协议 --&gt; ``` 在这个例子中,`getTerm`操作接受一个名为`term`的字符串...

    html,js,xml,wsdl,soap基础知识讲解

    通过`&lt;frameset&gt;`和`&lt;frame&gt;`标签定义,允许在一个浏览器窗口中显示多个页面。 ##### 12. HTML内联框架 使用`&lt;iframe&gt;`标签定义,可以在网页内嵌入另一个网页。 #### 第二节:JavaScript ##### 1. 什么是...

    spring-2.5.6api文档

    Spring Web Services模块提供了一个创建基于SOAP协议的Web服务的框架,包括WSDL第一和第二类风格的支持。 以上只是Spring 2.5.6 API文档的部分关键知识点,实际使用中还有许多其他功能,如AOP的自定义切面、定时...

    JAX-WS开发webservice示例详解

    4. **创建Web服务发布文件**:这通常是Web应用的`WEB-INF/wsdl`目录下的一个XML文件,用于配置服务发布。 5. **部署服务**:将Web应用打包成WAR文件,部署到Tomcat或其他应用服务器。 **3. 创建JAX-WS客户端** ...

    webservice开发文档

    ### WebService 开发文档知识点详解 #### 一、WebService 概述 WebService 是一种支持不同系统之间进行数据交换和服务调用的技术。它基于标准的 Internet 协议(如 HTTP),并通过 XML 格式来传递消息。WebService...

    解析xml文件文档+实例+配置

    4. 名空间:允许在同一个文档中使用来自不同来源的标签,避免命名冲突。 二、XML解析原理 1. 预处理:解析器首先检查XML文档的语法是否正确,如文档声明、编码声明等。 2. 解析:解析器读取XML文档,构建DOM...

    j2ee 5.0 api 帮助文档

    **J2EE 5.0 API 帮助文档详解** Java 企业版(Java Enterprise Edition,简称 J2EE)5.0 是一个用于构建分布式、多层的企业级应用程序的框架。这个版本引入了许多关键特性,提升了开发效率,增强了可移植性和可维护...

    Xdoclet介绍及示例.........

    #### 三、Xdoclet标签详解 Xdoclet通过在Java源码中使用特定的注释来标记需要处理的部分。下面通过一个具体的例子来详细介绍Xdoclet标签的使用方法: ```java /** @hibernate.class table="T_Party" */ public ...

    J2EE API帮助文档

    **J2EE API帮助文档详解** J2EE(Java 2 Platform, Enterprise Edition)是Java平台上用于构建企业级分布式应用程序的框架。它提供了一系列API,这些API覆盖了从数据库访问、事务管理到Web服务和安全等多个领域,为...

    webservice

    开发者可以使用WSDL文档了解如何与特定的WebService交互。 3. **UDDI(统一描述、发现和集成)**:UDDI是一种目录服务,允许企业注册和查找WebService。通过UDDI,服务消费者可以搜索到所需的服务并获取其WSDL描述...

    JAVA EE 5 API文档 CHM

    **JAVA EE 5 API文档详解** JAVA EE 5(Java Platform, Enterprise Edition 5),是Java平台上用于构建企业级应用的框架,它为开发者提供了丰富的API和服务,旨在简化开发过程,提高可移植性和可伸缩性。这个CHM...

    nc.uap.mde.wstools_1.0.3.zip

    本文将深入解析名为"nc.uap.mde.wstools_1.0.3.zip"的压缩包,它是一个专为NC(NetSuite China)开发Webservice接口提供的工具包,旨在简化开发过程,提升效率。 首先,我们来看标题"nc.uap.mde.wstools_1.0.3.zip...

    webservive学习笔记

    WSDL文档包含了服务的位置(端点地址)、可用的操作、消息格式以及数据类型等信息。它通过HTTP向外界公开,使得客户端程序能够理解和调用远程的WebService服务,无需事先了解底层实现细节。 综上所述,WebService...

    无废话XML

    一个有效的XML文档必须有且只有一个根元素,所有的元素都必须正确嵌套,即每个开始标签都有相应的结束标签。XML文档还应该遵循XML声明(),指定其版本信息。 XML命名空间(Namespaces): 在处理多个XML文档时,...

Global site tag (gtag.js) - Google Analytics