Architecture Net

       

Язык описания Web-служб (Web Services Description Language — WSDL)


Протокол SOAP описывает передаваемые данные Интерфейс Web-служб он не описывает Данные, передаваемые по протоколу SOAP, можно закодировать и самостоятельно Но лучше для этой цели создать вспомогательные классы (классы-заместители), которые будет использовать программа-клиент Ведь чтобы самостоятельно закодировать

данные, необхсцшо знать спецификацию SOAP до мельчайших подробностей и провести синтаксичесий разбор возвращаемого XML-пакета.

Язык WSDl(Web Services Description Language — язык описания Web-служб) предназначен для опиания интерфейса Web-служб. В качестве примера мы опишем с помощью языка WSDL нтерфейс Web-службы SimpleWebService, имеющей один метод Add (Сложение). Ипользовать язык WSDL для описания интерфейса Web-служб, которые для передачи днных используют другие протоколы, а не протокол SOAP, мы не будем. Чтобы увидетюписание на языке WSDL Web-службы SimpleWebService, введите в адресной строе броузера следующий унифицированный указатель информационного ресурса (URL)http: //localhost/SimpleWebService/Add.asmx?WSDL. Описание Web-службы в языке WSDL состоит из нескольких разделов. В разделе <types> (<типы>) опредлены следующие типы:

  • Add (Сложение). Описывает данные, передаваемые Web-службе по протоколу SOAP;
  • Addresponse. Описывает результаты, возвращаемые Web-службой клиенту по протжолу SOAP.
  • Тип Add (Сложение) имеет два элемента, каждый из которых встречается лишь один раз. Элементьимеют имена х и у и принадлежат типу long, определенному спецификацией XSD (XMLSchema Definition — Определение схемы XML). Возвращаемый параметр AddResponsecoдepжит один элемент AddResult, который встречается один раз и также принадлеэмт типу long, определенному, как мы уже знаем, в спецификации XSD (XML SchemaDefinition — Определение схемы XML). Обратите внимание, как рассмотренные типы >ке использовались ранее, при описании протокола SOAP.

    <types>
    <s:elemerz name="Add"> <s: comjl.exType> <s: sequence>
    <salement minOccurs="1" maxOccurs="1"



    name="x" type="s:int" />
    <s:element minOccurs="1" maxOccurs="1"

    name="y" type="s:int" />
    </s:sequence>
    </s:complexType>
    </s:element>
    <s:element name="AddResponse">
    <s:complexType>
    <s:sequence>
    <s:element minOccurs="1" maxOccurs="1"

    name="AddResult" type="s:int" />
    </s:sequence>
    </s:complexType>
    </s :elment>
    </types>

    В разделе :message> (<сообщение>) описывается использование этих типов в качестве параметре.

    <message name="AddSoapIn"> <!-- сообщение -->
    <part name="parameters" element="s0:Add" /> <!-- параметры -->
    </message> <!-- сообщение -->
    <message name="AddSoapOut"> <!-- сообщение -->
    <part name="parameters" element="s0:AddResponse" />
    <!-- параметры -->
    </message> <!-- сообщение -->

    В разделе <portType> (тип порта) с Web-службой сопоставляются отдельные Web-методы, которые описаны в элементах <operation> (<действие>). Если бы данная Web- служба использовала большее количество методов, тогда в разделе <portType> (тип порта) было бы больше элементов operation (действие) [Читатели, склонные проводить параллели, увидят здесь аналогию с интерфейсом модели компонентных объектов Microsoft (COM). ]. Операции ввода и вывода каждого метода связаны с соответствующими сообщениями, которые были определены раньше.

    <portType name="TestSoap">
    <operation name="Add"> <!-- операция -->
    <input message="s0:AddSoap!n" />
    <output message="s0:AddSoapOut" />
    </operation> <!-- операция -->
    </portType>

    В разделе <binding> (<связывание>) каждому действию ставится в соответствие способ кодирования и протокол передачи данных.

    <binding name="TestSoap" type="s0:TestSoap">




    <soap:binding
    transport="http://sohemas.xmlsoap.org/soap/http"
    style="dooument" /> <!-- стиль = "документ" -->
    <operation name="Add"> <!-- название операции -->
    <soap:operation soapAction="http://tempuri.org/Add" style="document" />
    <!-- стиль = "документ -->
    <input> <!-- ввод -->
    <soap:body use="literal" />
    </input> <!-- ввод -->
    <output> <!-- вывод -->
    <soap:body use="literal" />
    </output> <!-- вывод -->
    </operation> <!-- операция -->
    </binding>

    В разделе <service> (<служба>) указывается порт, используемый Web-службой, и адрес, по которому можно активизировать Web-службу.

    <service name="Test"> <!-- имя = "Испытание -->
    <

    port name="ТезtSoap" binding="s0:TestSoap">

    <!-- порт -->

    <soap:address location=
    "http://localhost/SimpleWebService/Add.asmx" />

    </port> <!-- порт -->
    </service>

    CompEbook.ru Железо, дизайн, обучение и другие


    Содержание раздела