Обзор языков описания RESTful API - Overview of RESTful API Description Languages

RESTful (Изобразительное State Transfer) API (интерфейс прикладного программирования) DL (языки описания) формальные языки разработан, чтобы предоставить структурированное описание RESTful веб-API это полезно как для человека, так и для автоматизированной машинной обработки. Языки описания API иногда называют языки описания интерфейса (IDL). Структурированное описание может быть использовано для создания документации для людей. программисты; такую ​​документацию может быть проще читать, чем документацию в свободной форме, поскольку вся документация, созданная одним и тем же инструментом, следует одним и тем же соглашениям о форматировании. Кроме того, язык описания обычно достаточно точен, чтобы позволить автоматическое создание различных программных артефактов, таких как библиотеки, для доступа к API с различных языков программирования, что снимает с программистов бремя их ручного создания.

История

Существуют два предыдущих основных языка описания: WSDL2.0 (Язык описания веб-служб) и WADL (Язык описания веб-приложений). Ни один из них не получил широкого распространения в отрасли для описания RESTful API, ссылаясь на плохую читаемость обоих и WADL, который фактически не может полностью описать RESTful API.[1]

Альтернативы

API, управляемые гипертекстом

Альтернативный подход к созданию RESTful API известен под аббревиатурой HATEOAS (Гипермедиа как двигатель состояния приложения ). При таком подходе клиентское программное обеспечение не записывается в описание статического интерфейса, передаваемое через документацию. Вместо этого клиенту предоставляется набор точек входа, и API обнаруживается динамически посредством взаимодействия с этими конечными точками. HATEOAS был представлен в Рой Филдинг докторская диссертация Архитектурные стили и проектирование сетевых архитектур программного обеспечения. HATEOAS был оригинальным видением RESTful API, которое отличало их от RPC механизмы.[2]

Список списков рассылки RESTful API

Список языков описания данных

Значительная часть описания RESTful API - это спецификация возвращаемых структур данных. IDL может либо указать свой собственный формат, либо использовать существующий формат описания данных. Замечательный пример, который используют многие RESTful API DL: Схема JSON.

  • json: api
  • Схема JSON
    • используется OpenAPI, Google APIs Discovery,[6] Документы ввода / вывода
  • Apache Avro
    • https://avro.apache.org/
    • как язык описания интерфейса, так и язык описания данных
  • JSON-RPC 2.0
    • используется барристером

Сравнение списков рассылки RESTful API

Сообщество RESTful API DL активно, и ситуация все еще меняется. Согласно презентации Akana, наиболее активными проектами в этой области являются OpenAPI, RAML и API Blueprint.[1]

СпонсорНачальная фиксацияПоследний стабильный выпускСтабильная дата выходаЛицензия на программное обеспечение[7]ФорматОткрытый исходный кодГенерация кода (клиент)Генерация кода (сервер)
RAMLMuleSoftСентябрь 20131.016 мая, 2016Apache 2.0YAMLдадада
Схема APIПасекаАпрель 2013Массачусетский технологический институтMarkdownдаНетНет
OpenAPIИнициатива открытого API (OAI)Июль 2011 г.3.026 июля 2017 г.Apache 2.0JSON или YAMLдадада
СЕРИНУНИФОР20112.0Декабрь 2014 г.Creative CommonsRDFдаНетда

Каркасы

Многие серверные инфраструктуры взаимодействуют с одним или несколькими IDL.

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

  1. ^ а б http://www.slideshare.net/SOA_Software/api-description-languages
  2. ^ Филдинг, Рой. «API REST должны быть гипертекстовыми». Получено 4 ноября 2015.
  3. ^ «Протокол открытых данных OASIS (OData) TC - OASIS».
  4. ^ «Барристер ПКР - О компании».
  5. ^ Лира, Хермано Альбукерке; Дантас, Хосе Ренато Виллела; Мунис, Бруно де Азеведо; Нуньес, Тадеу Матос; Фариас, Педро Порфирио Мунис (01.01.2015). «Подход к поддержке целостности данных для веб-служб с использованием семантических интерфейсов RESTful». Материалы 24-й Международной конференции по всемирной паутине. WWW '15 Товарищ. Нью-Йорк, Нью-Йорк, США: ACM: 1485–1490. Дои:10.1145/2740908.2743042. ISBN  9781450334730.
  6. ^ https://developers.google.com/discovery/v1/reference/apis
  7. ^ Лицензии здесь представляют собой краткое изложение и не считаются полными заявлениями о лицензиях. Некоторые пакеты могут использовать библиотеки под разными лицензиями.

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