WSDL - Ejemplo
A continuación se muestra un archivo WSDL que se proporciona para demostrar un programa WSDL simple.
Supongamos que el servicio proporciona una única función disponible públicamente, llamada sayHello . Esta función espera un parámetro de cadena única y devuelve un saludo de cadena única. Por ejemplo, si pasa el parámetro mundo , la función de servicio sayHello devuelve el saludo, "¡Hola, mundo!".
Ejemplo
Contenido del archivo HelloService.wsdl -
<definitions name = "HelloService"
targetNamespace = "http://www.examples.com/wsdl/HelloService.wsdl"
xmlns = "http://schemas.xmlsoap.org/wsdl/"
xmlns:soap = "http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:tns = "http://www.examples.com/wsdl/HelloService.wsdl"
xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
<message name = "SayHelloRequest">
<part name = "firstName" type = "xsd:string"/>
</message>
<message name = "SayHelloResponse">
<part name = "greeting" type = "xsd:string"/>
</message>
<portType name = "Hello_PortType">
<operation name = "sayHello">
<input message = "tns:SayHelloRequest"/>
<output message = "tns:SayHelloResponse"/>
</operation>
</portType>
<binding name = "Hello_Binding" type = "tns:Hello_PortType">
<soap:binding style = "rpc"
transport = "http://schemas.xmlsoap.org/soap/http"/>
<operation name = "sayHello">
<soap:operation soapAction = "sayHello"/>
<input>
<soap:body
encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
namespace = "urn:examples:helloservice"
use = "encoded"/>
</input>
<output>
<soap:body
encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
namespace = "urn:examples:helloservice"
use = "encoded"/>
</output>
</operation>
</binding>
<service name = "Hello_Service">
<documentation>WSDL File for HelloService</documentation>
<port binding = "tns:Hello_Binding" name = "Hello_Port">
<soap:address
location = "http://www.examples.com/SayHello/" />
</port>
</service>
</definitions>
Análisis de ejemplo
Definitions - HelloService
Type - Utilizando tipos de datos integrados y definidos en XMLSchema.
Message -
sayHelloRequest - parámetro firstName
sayHelloresponse - valor de retorno del saludo
Port Type - operación sayHello que consta de un servicio de solicitud y respuesta.
Binding - Dirección para utilizar el protocolo de transporte SOAP HTTP.
Service - Servicio disponible en http://www.examples.com/SayHello/
Port - Asocia el enlace con la URI http://www.examples.com/SayHello/ donde se puede acceder al servicio en ejecución.