SOAP - Википедия - SOAP

МЫЛО
Веб-сервис xrpc.png
СемьяОбмен сообщениями протокол
РазработаноДэйв Винер, Дон Бокс, Боб Аткинсон и Мохсен Аль-Госейн
Впервые появилсяПервоначально как XML-RPC в июне 1998 г.; 22 года назад (Июнь 1998 г.)
Стабильный выпуск
1.2 / 27 апреля 2007 г.; 13 лет назад (2007-04-27)

МЫЛО (ранее сокращение от Простой протокол доступа к объектам) это сообщение протокол спецификация для обмена структурированной информацией при реализации веб-сервисы в компьютерная сеть. Его цель - предоставить расширяемость, нейтралитет, многословие и независимость.[расплывчатый ] Оно использует Набор информации XML для своего формат сообщения, и полагается на прикладной уровень протоколы, чаще всего Протокол передачи гипертекста (HTTP), хотя некоторые устаревшие системы обмениваются данными через Простой протокол передачи почты (SMTP) для согласования и передачи сообщений.

SOAP позволяет разработчикам вызывать процессы, работающие в разных операционных системах (например, Windows, macOS, и Linux ) для аутентификации, авторизации и связи с помощью расширяемый язык разметки (XML). Поскольку веб-протоколы, такие как HTTP, установлены и работают во всех операционных системах, SOAP позволяет клиентам вызывать веб-службы и получать ответы независимо от языка и платформ.

Характеристики

SOAP обеспечивает уровень протокола обмена сообщениями стек протоколов веб-служб для веб-сервисов. Это протокол на основе XML, состоящий из трех частей:

  • конверт, определяющий структуру сообщения[1] и как это обработать
  • набор правил кодирования для выражения экземпляров определяемых приложением типов данных
  • соглашение для представления вызовов процедур и ответов

SOAP имеет три основные характеристики:

  1. расширяемость (безопасность и WS-адресация находятся среди разрабатываемых расширений)
  2. нейтралитет (SOAP может работать по любому протоколу, например HTTP, SMTP, TCP, UDP )
  3. независимость (SOAP допускает любые модель программирования )

В качестве примера того, что могут делать процедуры SOAP, приложение может отправить запрос SOAP на сервер, на котором включены веб-службы, такие как база данных цен на недвижимость, с параметрами для поиска. Затем сервер возвращает ответ SOAP (документ в формате XML с результирующими данными), например, цены, местоположение, характеристики. Поскольку сгенерированные данные поступают в стандартизованном формате, пригодном для машинного анализа, запрашивающее приложение может интегрировать их напрямую.

Архитектура SOAP состоит из нескольких уровней спецификаций для:

  • формат сообщения
  • Шаблоны обмена сообщениями (MEP)
  • привязки базовых транспортных протоколов
  • модели обработки сообщений
  • расширяемость протокола

SOAP развился как преемник XML-RPC, хотя нейтральность транспорта и взаимодействия он заимствует у адресации веб-служб.[2] и конверт / заголовок / тело из другого места (возможно, из WDDX ).[нужна цитата ]

История

SOAP был разработан как протокол объектного доступа и выпущен как XML-RPC в июне 1998 г. в рамках программы Frontier 5.1. Дэйв Винер, Дон Бокс, Боб Аткинсон и Мохсен Аль-Госейн за Microsoft, где работали Аткинсон и Аль-Госейн.[3] Спецификация не была доступна, пока она не была отправлена ​​в IETF 13 сентября 1999 г.[4][5] По словам Дона Бокса, это произошло из-за политики внутри Microsoft.[6] Из-за колебаний Microsoft Дэйв Винер отправил XML-RPC в 1998 г.[7]

Представленный Интернет-проект не достиг RFC статус и поэтому не считается «стандартом» как таковой. Версия 1.1 спецификации была опубликована в W3C Note 8 мая 2000 г.[8] С версии 1.1 не дошел Рекомендация W3C статусной, она тоже не может считаться «стандартной». Версия 1.2 спецификации, однако, стала W3C рекомендация от 24 июня 2003 г.

Спецификация SOAP[9] поддерживается Рабочей группой протокола XML[10] из Консорциум World Wide Web до закрытия группы 10 июля 2009 г. МЫЛО первоначально означало «протокол простого доступа к объектам», но в версии 1.2 стандарта этот акроним был удален.[11]

После того, как SOAP был впервые представлен, он стал основным слоем более сложного набора веб-сервисы, на основе Язык описания веб-служб (WSDL), Схема XML и Обнаружение и интеграция универсального описания (UDDI). Эти различные сервисы, особенно UDDI, оказались гораздо менее интересными, но их понимание дает полное понимание ожидаемой роли SOAP по сравнению с тем, как на самом деле развивались веб-сервисы.

Терминология SOAP

Спецификацию SOAP можно в широком смысле определить как состоящую из следующих трех концептуальных компонентов: концепции протокола, концепции инкапсуляции и концепции сети.[12]

Концепции протокола

МЫЛО
Это набор правил, формализующих и управляющих форматом и правилами обработки информации, передаваемой между отправителем SOAP и получателем SOAP.
Узлы SOAP
Это физические / логические машины с блоками обработки, которые используются для передачи / пересылки, приема и обработки сообщений SOAP. Это аналог узлы в сети.
SOAP-роли
На пути сообщения SOAP все узлы принимают на себя определенную роль. Роль узла определяет действие, которое узел выполняет с полученным сообщением. Например, роль "никто" означает, что ни один узел не будет обрабатывать заголовок SOAP каким-либо образом и просто передавать сообщение по своему пути.
Привязка протокола SOAP
Сообщение SOAP должно работать вместе с другими протоколами для передачи по сети. Например, сообщение SOAP может использовать TCP как протокол нижнего уровня для передачи сообщений. Эти привязки определены в структуре привязки протокола SOAP.[13]
Возможности SOAP
SOAP предоставляет только среду обмена сообщениями. Однако его можно расширить, добавив такие функции, как надежность, безопасность и т. Д. При добавлении функций в структуру SOAP необходимо соблюдать правила.
Модуль SOAP
Набор спецификаций, касающихся семантики заголовка SOAP, для описания любых новых функций, расширяемых в SOAP. Модуль должен реализовывать ноль или более функций. SOAP требует, чтобы модули придерживались установленных правил.[14]

Концепции инкапсуляции данных

Сообщение SOAP
Представляет информацию, которой обмениваются 2 узла SOAP.
Конверт SOAP
Это включающий элемент сообщения XML, идентифицирующий его как сообщение SOAP.
Блок заголовка SOAP
Заголовок SOAP может содержать более одного из этих блоков, каждый из которых является дискретным вычислительным блоком внутри заголовка. В общем, SOAP роль информация используется для целевых узлов на пути. Говорят, что блок заголовка нацелен на узел SOAP, если роль SOAP для блока заголовка - это имя роли, в которой работает узел SOAP. (например: блок заголовка SOAP с атрибутом роли как ultimateReceiver нацелен только на целевой узел, который играет эту роль. Заголовок с атрибутом роли как Следующий нацелен на каждого посредника, а также на целевой узел.)
Заголовок SOAP
Набор из одного или нескольких блоков заголовков, предназначенных для каждого получателя SOAP.
Тело SOAP
Содержит тело сообщения, предназначенное для получателя SOAP. Интерпретация и обработка тела SOAP определяется блоками заголовков.
Ошибка SOAP
Если узел SOAP не может обработать сообщение SOAP, он добавляет информацию об ошибке в элемент ошибки SOAP. Этот элемент содержится в теле SOAP как дочерний элемент.

Концепции отправителя и получателя сообщений

Отправитель SOAP
Узел, передающий сообщение SOAP.
Приемник SOAP
Узел, получающий сообщение SOAP. (Может быть посредником или конечным узлом).
Путь сообщения SOAP
Путь, состоящий из всех узлов, по которым сообщение SOAP достигло конечного узла.
Первоначальный отправитель SOAP
Это узел, который отправил сообщение SOAP для передачи. Это корень пути сообщения SOAP.
SOAP-посредник
Все узлы между отправителем SOAP и предполагаемым местом назначения SOAP. Он обрабатывает блоки заголовка SOAP, нацеленные на него, и действует для пересылки сообщения SOAP конечному получателю SOAP.
Окончательный приемник SOAP
Целевой получатель сообщения SOAP. Этот узел отвечает за обработку тела сообщения и любых нацеленных на него блоков заголовков.

Технические характеристики

Структура SOAP

Спецификация SOAP определяет структуру обмена сообщениями, которая состоит из:

  • В Модель обработки SOAP, определение правил обработки SOAP-сообщения[15]
  • В Модель расширяемости SOAP определение концепций функций SOAP и модулей SOAP[15]
  • В Привязка базового протокола SOAP структура, описывающая правила для определения привязки к базовому протоколу, который может использоваться для обмена сообщениями SOAP между узлами SOAP[15]
  • В Конструкция сообщения SOAP определение структуры сообщения SOAP[15]

Строительные блоки SOAP

Сообщение SOAP - это обычный XML-документ, содержащий следующие элементы:

ЭлементОписаниенеобходимые
КонвертИдентифицирует XML-документ как сообщение SOAP.да
ЗаголовокСодержит информацию заголовка.Нет
ТелоСодержит информацию о вызовах и ответах.да
НеисправностьПредоставляет информацию об ошибках, возникших при обработке сообщения.Нет

Транспортные методы

И то и другое SMTP и HTTP являются действительными протоколами прикладного уровня, используемыми в качестве транспорта для SOAP, но HTTP получил более широкое распространение, поскольку он хорошо работает с современной интернет-инфраструктурой; в частности, HTTP хорошо работает с сетью брандмауэры. SOAP также может использоваться HTTPS (который является тем же протоколом, что и HTTP на уровне приложения, но использует зашифрованный транспортный протокол внизу) с простой или взаимной аутентификацией; это отстаиваемый WS-I метод обеспечения безопасности веб-службы, как указано в Базовый профиль WS-I 1.1.

Это главное преимущество перед другими распределенными протоколами, такими как GIOP / IIOP или DCOM, которые обычно фильтруются брандмауэрами. Мыло поверх AMQP это еще одна возможность, поддерживаемая некоторыми реализациями. SOAP также имеет преимущество перед DCOM что на него не влияют права безопасности, настроенные на машинах, которые требуют знания как передающих, так и принимающих узлов. Это позволяет слабо связать SOAP, что невозможно с DCOM. Также есть SOAP-поверх-UDP ОАЗИС стандарт.

Формат сообщения

Набор информации XML был выбран в качестве стандартного формата сообщений из-за его широкого использования крупными корпорациями и Открытый исходный код усилия по развитию. Обычно набор информации XML сериализованный так как XML. Широкий выбор свободно доступных инструменты значительно упрощает переход к реализации на основе SOAP. Довольно длинный синтаксис из XML может быть как преимуществом, так и недостатком. Хотя он способствует удобочитаемости для людей, облегчает обнаружение ошибок и позволяет избежать проблем совместимости, таких как порядок байтов (порядок байтов ), это может замедлить скорость обработки и быть громоздким. Например, CORBA, GIOP, ICE, и DCOM использовать гораздо более короткие двоичные форматы сообщений. С другой стороны, доступны аппаратные средства для ускорения обработки XML Сообщения.[16][17] Двоичный XML также изучается как средство для оптимизации требований к пропускной способности XML. XML-сообщения из-за их самодокументируемого характера обычно имеют больше «накладных расходов» (например, заголовки, вложенные теги, разделители), чем фактические данные, в отличие от более ранних протоколов, где накладные расходы обычно составлял относительно небольшой процент от общего сообщения.

В финансовых сообщениях SOAP приводил к сообщению в 2–4 раза больше, чем предыдущие протоколы. ИСПРАВИТЬ (Обмен финансовой информацией) и CDR (Общее представление данных).[18]

Информационный набор XML не требует сериализации в XML. Например, CSV и JSON Представления XML-инфо-набора существуют. Также нет необходимости указывать общую структуру преобразования. Концепция привязок SOAP допускает определенные привязки для конкретного приложения. Недостатком является то, что и отправители, и получатели должны поддерживать эту недавно определенную привязку.

Пример сообщения (инкапсулировано в HTTP)

В сообщении ниже запрашивается цена акций AT&T (биржевой тикер "T").

СООБЩЕНИЕ /В наличии HTTP/1.1Хост: www.example.orgТип содержимого: приложение / мыло + xml; charset = utf-8Content-Length: 299SOAPAction: "http://www.w3.org/2003/05/soap-envelope"<?xml version="1.0"?><мыло: Конверт xmlns: мыло ="http://www.w3.org/2003/05/soap-envelope" xmlns: m ="http://www.example.org">  <soap:Header>  </soap:Header>  <soap:Body>    <m:GetStockPrice>      <m:StockName>Т</m:StockName>    </m:GetStockPrice>  </soap:Body></soap:Envelope>

Техническая критика

Преимущества

  • Характеристика нейтральности SOAP явно делает его пригодным для использования с любым транспортным протоколом. Реализации часто используют HTTP в качестве транспортного протокола, но могут использоваться и другие популярные транспортные протоколы. Например, SOAP можно также использовать через SMTP, JMS[19][20] и очереди сообщений.
  • SOAP в сочетании с обменом сообщениями и ответами HTTP легко туннелируется через существующие брандмауэры и прокси-серверы и, следовательно, не требует модификации широко распространенных вычислительных и коммуникационных инфраструктур, существующих для обработки сообщений сообщений и ответов HTTP.
  • В SOAP доступны все возможности XML, включая простую интернационализацию и расширяемость с помощью пространств имен XML.

Недостатки

  • При использовании стандартной реализации и привязки SOAP / HTTP по умолчанию информационный набор XML сериализуется как XML. Чтобы повысить производительность для особого случая XML со встроенными двоичными объектами, Механизм оптимизации передачи сообщений был представлен.
  • Если вы полагаетесь на HTTP в качестве транспортного протокола и не используете Адресация веб-служб или Корпоративная служебная шина, роли взаимодействующих сторон фиксированы. Только одна сторона (клиент) может пользоваться услугами другой стороны.
  • SOAP менее «прост», чем следует из названия. Многословие протокола, низкая скорость синтаксического анализа XML и отсутствие стандартизированной модели взаимодействия привели к доминированию сервисов, использующих HTTP протокол более прямо. См., Например, ОСТАЛЬНЫЕ.

Смотрите также

использованная литература

  1. ^ Хирш, Фредерик; Кемп, Джон; Илкка, Яни (11 января 2007 г.). Мобильные веб-сервисы: архитектура и реализация. John Wiley & Sons (опубликовано в 2007 г.). п. 27. ISBN  9780470032596. Получено 2014-09-15. Протокол простого доступа к объектам (SOAP) определяет структуру конверта обмена сообщениями, предназначенную для переноса полезной нагрузки приложения в одной части конверта (тела сообщения) и управляющей информации в другой (заголовок сообщения).
  2. ^ «Адресация веб-служб (WS-адресация)». www.w3.org. Получено 2016-09-15.
  3. ^ "Эксклюзивный журнал разработчиков .NET" Indigo "Интервью с Microsoft Don Box". Dotnet.sys-con.com. Получено 2012-10-04.
  4. ^ «Титульные страницы XML по истории SOAP». Coverpages.org. Получено 2003-07-22.
  5. ^ «SOAP: простой протокол доступа к объектам». Сентябрь 1999 г.
  6. ^ «Дон Бокс по истории SOAP». XML.com. 2001-04-04.
  7. ^ «XML-RPC для новичков». 1998-07-14. Архивировано из оригинал 12 октября 1999 г.
  8. ^ «Примечание W3C о протоколе простого доступа к объектам (SOAP) 1.1». W3C. 2000-05-08.
  9. ^ «Спецификации SOAP». W3C. Получено 2014-03-29.
  10. ^ «Рабочая группа W3C по протоколу XML». W3C. Получено 2014-03-29.
  11. ^ «SOAP версии 1.2, часть 1: платформа обмена сообщениями (второе издание)». W3C. 27 апреля 2007 г.. Получено 2012-06-15. Примечание. В предыдущих версиях этой спецификации имя SOAP было акронимом. Это уже не так. (Под разделом 1. Введение)
  12. ^ «SOAP версии 1.2, часть 1: платформа обмена сообщениями (второе издание)». www.w3.org. Получено 2016-09-14.
  13. ^ «Предложение о структуре привязки». www.w3.org. Получено 2016-09-14.
  14. ^ «SOAP версии 1.2, часть 1: платформа обмена сообщениями (второе издание)». www.w3.org. Получено 2016-09-14.
  15. ^ а б c d «SOAP версии 1.2, часть 1: платформа обмена сообщениями (второе издание)». www.w3.org.
  16. ^ "IBM Datapower". 306.ibm.com. 2011-11-30. Получено 2012-10-04.
  17. ^ "IBM Zurich XML Accelerator Engine" (PDF). Получено 2012-10-04.
  18. ^ «Оценка SOAP для высокопроизводительных бизнес-приложений: торговые системы в реальном времени». Tenermerx Pty Ltd Технологический университет, Сидней. 2011-11-30. Получено 2013-03-14.
  19. ^ "SOAP через протокол JMS". IBM. Получено 22 марта, 2020.
  20. ^ «Часто задаваемые вопросы по SOAP-JMS». Рабочая группа привязки SOAP-JMS. Получено 22 марта, 2020.

дальнейшее чтение

внешние ссылки