Что такое api в тенгизе. Что такое API в веб-приложениях и зачем он нужен

Определение: Прикладной программный интерфейс (application programming interface, API) - это описание способа, который позволяет какому-либо фрагменту ПО обращаться к другой программе за получением сервиса. Этим сервисом может быть предоставление доступа к данным или выполнение конкретной функции. Интерфейсы разработаны для большей части ПО уровня предприятия и играют критически важную роль в операционных системах, которые управляют большинством базовых функций компьютера

Нередко нам приходится обращаться к другим людям с просьбой выполнить работу, которую не удается по тем или иным причинам сделать самостоятельно, например открыть депозитную ячейку в банке. Точно так же практически все программное обеспечение требует использования других программ для выполнения определенных функций. Для этой цели применяется набор стандартизованных запросов (их называют прикладными программными интерфейсами), определенных для программы, к которой адресован запрос. Почти каждое приложение обращается к API базовой операционной системы для выполнения таких основных функций, как доступ к файловой системе.

По существу, прикладной интерфейс программы определяет корректный способ, который разработчик может использовать для вызова сервисов, необходимых конкретной программе. Разработчики могут выполнять запросы, добавляя вызовы в код своих приложений. Синтаксис описывается в документации вызываемого приложения.

Предоставляя средства для запроса программных сервисов, API гарантирует доступ или возможность открытия приложения. По словам Джоша Уолкера, аналитика компании Forrester Research, «создание приложения без API напоминает строительство дома без дверей. Для любой вычислительной задачи прикладной программный интерфейс открывает окна и двери для обмена информацией».

Кроме того, прикладные программные интерфейсы обеспечивают взаимодействие приложений между собой. В состав корпоративных приложений компании SAP входит API, получивший название BAPI, который обеспечивает другим приложениям доступ к бизнес-данным. Когда в отрасли утверждается стандарт на данные, вслед за этим обычно появляется единый прикладной программный интерфейс, который обеспечивает доступ к приложениям, обрабатывающим эти данные.

Промежуточное программное обеспечение действует как стандартизованный, аналогичный API-интерфейс, который позволяет взаимодействовать приложениям, написанным для разных платформ или на разных языках.

По мнению Адама Браунштейна, аналитика компании Robert Frances Group, хотя API и обеспечивают быстрый и удобный способ доступа к приложению, они могут оказаться чересчур ограниченным средством для пользователей, которым требуются более широкие возможности, в частности для независимых производителей программного обеспечения. Свободно распространяемые программы позволяют получить текст любой команды и операции в приложении и тем самым обеспечивают большую гибкость. Но на то, чтобы разобраться в исходном тексте, может уйти слишком много времени, а кроме того, при таком подходе неминуемо возникают вопросы об интеллектуальной собственности автора.

Когда компания Novell в прошлом году сообщила о намерении предоставить широкой публике доступ к исходным текстам своего программного обеспечения Novell Directory Services (NDS), Крис Стоун, бывший в то время вице-президентом Novell, заявил, что большинство корпоративных разработчиков не хотят копаться в текстах свободно распространяемого обеспечения. На самом деле, по его словам, разработчики хотят получить дополнительные наборы API, с помощью которых они смогли бы работать быстрее. И до сих пор исходные тексты NDS так и не опубликованы.

Корпоративные разработчики должны решить, нужно ли включать прикладные интерфейсы в создаваемые ими приложения. Со временем вероятность того, что другому разработчику потребуется обратиться к сервисам этого приложения, только увеличивается. По словам Браунштейна, создание API избавит программистов, которые впоследствии будут работать с данным приложением, от необходимости искать нужный текст и разбираться в том, как устроен код.

Прикладные программные интерфейсы создавать несложно, но, как отметил Ларри Перлштейн, аналитик компании GartnerGroup, они могут оказаться трудными для изучения. Разработчики приложений и производители должны постоянно думать о том, будут ли их прикладные программные интерфейсы понятны последующим разработчикам. «API бесполезен, если на него нет документации», - подчеркнул Перлштейн, хотя некоторые производители оставляют свои API недокументированными.

API как оружие против конкурентов

Если компания хочет разочаровать разработчиков, она может хранить свои API в секрете или быстро их изменять. Многие критики корпорации Microsoft, в том числе государственные прокуроры и конкуренты, обвиняют компанию в том, что она не чурается подобной практики.

Эндрю Шульман описал несколько скрытых API операционной системы Windows в своей книге «Недокументированная Windows». Сейчас он работает консультантом в компании Caldera, которая предъявила иск корпорации Microsoft, обвиняя ее в нарушении антимонопольного законодательства. Теперь вместо сокрытия API, как пишет Шульман, «Windows имеет архитектуру типа?кухонной раковины?, которая позволяет скрыть новые прикладные программные интерфейсы. Такое?перемешивание? API - это попытка не допустить клонирования Windows».

Судья Томас Пенфилд Джексон привел аналогичные аргументы в своем выступлении 5 ноября в рамках слушаний по делу министерства юстиции против компании Microsoft. Он сказал, что «попытка клонировать API 32-разрядных Windows настолько дорогое и бесперспективное занятие, что появление конкурента для Windows становится практически невозможным».

Но Перлштейн отметил, что критикуя компанию за ее методы поддержки Windows API, конкуренты Microsoft дают волю своей зависти в ущерб справедливости. Представитель Microsoft Джим Куллинан утверждает, что Microsoft постоянно совершенствует Windows, а также обновляет и добавляет прикладные программные интерфейсы, поскольку снижение скорости модернизации могло бы привести к невыполнению сроков выпуска.

Прикладные программные интерфейсы и вы

Прикладные программные интерфейсы (API) производят впечатление чего-то таинственного, а производители или разработчики не прочь поразмахивать ими как волшебными палочками, способными решить все проблемы. Но на самом деле API могут быть очень простыми и мощными. Каждый из нас использует нечто похожее на API в повседневной жизни, когда, к примеру, обращается к кому-нибудь за услугой. API предлагают меньшую гибкость, чем свободно распространяемый код, но большую, чем полностью закрытые приложения.

Представьте, что у вас есть три соседа. Закрытый Зиновий, Открытый Оскар и API Анн. Каждый из них - это аналог приложения. Как и любому из соседей, вам иногда нужно у них что-нибудь позаимствовать, например газонокосилку. Это эквивалент интеграции приложений.

Закрытый Зиновий просто не оказывает вам никаких услуг. Он косит свою собственную траву за огородившим его дом высоким забором. Вы не только не имеете возможности попросить его о чем-либо, но даже не можете войти к нему во двор, чтобы попытаться поговорить, поскольку в его заборе нет калитки. Такое приложение, как Закрытый Зиновий, не предоставляет ни исходных текстов, ни прикладного программного интерфейса.

Открытый Оскар - полная ему противоположность. Он настолько открыт, что разрешает вам свободно входить в свой двор всякий раз, когда вы захотите, и даже ремонтировать его косилку, поэтому он очень часто откликается на ваши просьбы. Конечно, как только вы измените конструкцию газонокосилки, описанную в руководстве, вам самому придется заниматься ее ремонтом и обслуживанием. Такие приложения, как Открытый Оскар, имеют открытый код, который позволяет вам менять его так, как вы того захотите.

API Анна позволит вам воспользоваться ее газонокосилкой, если вы правильно ее об этом попросите (вызвав прикладной программный интерфейс «дайкосилку» в тексте своего приложения). Вы не можете войти в калитку без такого запроса и не можете включить газонокосилку и подстричь траву. Но вы можете воспользоваться этой услугой (по стрижке газона) в любой момент, когда захотите. Наиболее часто на предприятиях используются именно такие, закрытые, но имеющие API приложения, как Анна.

По определению из википедии, API - набор готовых классов, процедур, функций, структур и констант, предоставляемых приложением (библиотекой, сервисом) для использования во внешних программных продуктах. Используется программистами для написания всевозможных приложений.

Но так как многое в википедии не доступно для понимания многими людьми, я постараюсь объяснить на пальцах что такое API и для чего их обычно делают, и как используют.

API бывают совершенно разные, но для примера я выбрал ситуацию, когда у нас есть сеть магазинов и всего одна общая база данных. Представьте, что вы владеете партнеркой. Партнерка работает по следующему принцыпу: человек регистрируется в партнерской программе и получает движок магазина. Дальше он может поставить этот магазин у себя на хостинге и начать работать. Но все данные на этом магазине берутся из нашей базы, то есть нам надо давать каждому партнеру доступ к нашей драгоценной базе данных. Представляете насколько это опасно? Ведь нам необходимо открыть доступ к базе из вне, что бы все магазины партнеров могли работать с ней. А что будет если данные доступа попадут в руки к злоумышленникам?

Вот тут нам и поможет API. Вместо того, что бы давать доступ к базе, мы просто сделаем API, через который магазины партнеров будут получать информацию. Таким образом с базой данных будет работать только наш скрипт API, а магазины будут работать уже с этим скриптом.

Как это работает?
Например магазин посылает запрос на наше API
http://ourapi.com/get_books?limit=20
и наше API понимает, что ему надо отдать список книг, состоящий из 20 экземпляров, ведь мы передали параметр limit равный 20. Наш скрипт(API) делает запрос к базе, получает список книг и возвращает их магазину(по сути, просто выводит на экран) в определенном формате. Формат, в котором API возвращает информацию может быть совершенно любым, главное что бы его понимали наши магазины. Это может быть JSON, сериализованный массив или XML. Это уже не важно, главное что бы вы поняли принцип.

Набор команд, которые понимает API вы определяете сами. Например в нашем случае это могли бы быть такие команды, как получение списка книг, получение списка категорий, получение популярных книг, получение новых книг и т.д. Таким образом, даже если злоумышленник получит возможность обращаться к нашему API, все что он сможет сделать это получить список книг, а это не ставит перед нашей базой данных никаких угроз.

Надеюсь мне удалось объяснить что такое API на простом примере. Если остались вопросы, задавайте их в комментах или на форуме и мы с радостью вам поможем в их решении.

, функций , структур или констант), которыми одна компьютерная программа может взаимодействовать с другой программой. Обычно входит в описание какого-либо интернет-протокола (например, RFC ), программного каркаса (фреймворка) или стандарта вызовов функций операционной системы . Часто реализуется отдельной программной библиотекой или сервисом операционной системы. Используется программистами при написании всевозможных приложений.

API как средство интеграции приложений

API определяет функциональность, которую предоставляет программа (модуль , библиотека), при этом API позволяет абстрагироваться от того, как именно эта функциональность реализована.

Если программу (модуль, библиотеку) рассматривать как чёрный ящик , то API - это множество «ручек», которые доступны пользователю данного ящика и которые он может вертеть и дёргать.

Программные компоненты взаимодействуют друг с другом посредством API. При этом обычно компоненты образуют иерархию - высокоуровневые компоненты используют API низкоуровневых компонентов, а те, в свою очередь, используют API ещё более низкоуровневых компонентов.

По такому принципу построены протоколы передачи данных по Интернет . Стандартный стек протоколов (сетевая модель OSI) содержит 7 уровней (от физического уровня передачи бит до уровня протоколов приложений, подобных протоколам HTTP и IMAP). Каждый уровень пользуется функциональностью предыдущего («нижележащего») уровня передачи данных и, в свою очередь, предоставляет нужную функциональность следующему («вышележащему») уровню.

Важно заметить, что понятие протокола близко по смыслу к понятию API. И то, и другое является абстракцией функциональности, только в первом случае речь идёт о передаче данных, а во втором - о взаимодействии приложений.

API библиотеки функций и классов включает в себя описание сигнатур и семантики функций .

Сигнатура функции

Иногда различают сигнатуру вызова и сигнатуру реализации функции. Сигнатура вызова обычно составляется по синтаксической конструкции вызова функции с учётом сигнатуры области видимости данной функции, имени функции, последовательности фактических типов аргументов в вызове и типе результата. В сигнатуре реализации обычно участвуют некоторые элементы из синтаксической конструкции объявления функции: спецификатор области видимости функции, её имя и последовательность формальных типов аргументов.

Например, в языке программирования C++ простая функция однозначно опознаётся компилятором по её имени и последовательности типов её аргументов, что составляет сигнатуру функции в этом языке. Если функция является методом некоторого класса, то в сигнатуре будет участвовать и имя класса.

В индустрии программного обеспечения общие стандартные API для стандартной функциональности играют важную роль, так как они гарантируют, что все программы, использующие общий API, будут работать одинаково хорошо или, по крайней мере, типичным привычным образом. В случае API графических интерфейсов это означает, что программы будут иметь похожий пользовательский интерфейс, что облегчает процесс освоения новых программных продуктов.

С другой стороны, отличия в API различных операционных систем существенно затрудняют перенос приложений между платформами. Существуют различные методы обхода этой сложности - написание «промежуточных» API (API графических интерфейсов wxWidgets , GTK и т. п.), написание библиотек, которые отображают системные вызовы одной ОС в системные вызовы другой ОС (такие среды исполнения, как Wine , cygwin и т. п.), введение стандартов кодирования в языках программирования (например, стандартная библиотека языка C), написание интерпретируемых языков, реализуемых на разных платформах ( , python , perl , php , tcl , Java и т. д.).

Также необходимо отметить, что в распоряжении программиста часто находится несколько различных API, позволяющих добиться одного и того же результата. При этом каждый API обычно реализован с использованием API программных компонент более низкого уровня абстракции.

Например: для того, чтобы увидеть в браузере строчку «Hello, world! », достаточно лишь создать HTML -документ с минимальным заголовком и простейшим телом, содержащим данную строку. Когда браузер откроет этот документ , программа-браузер передаст имя файла (или уже открытый дескриптор файла) библиотеке, обрабатывающей HTML-документы, та, в свою очередь, при помощи API операционной системы прочитает этот файл и разберётся в его устройстве, затем последовательно вызовет через API библиотеки стандартных графических примитивов операции типа «очистить окошко», «написать „Hello, world!“ выбранным шрифтом». Во время выполнения этих операций библиотека графических примитивов обратится к библиотеке оконного интерфейса с соответствующими запросами, уже эта библиотека обратится к API операционной системы, чтобы записать данные в буфер видеокарты .

При этом практически на каждом из уровней реально существует несколько возможных альтернативных API. Например: мы могли бы писать исходный документ не на HTML, а на LaTeX , для отображения могли бы использовать любой браузер. К тому же, различные браузеры, используют различные HTML-библиотеки, и, кроме того, всё это может быть собрано с использованием различных библиотек примитивов и на различных операционных системах.

Основными сложностями существующих многоуровневых систем API, таким образом, являются:

  • Сложность портирования программного кода с одной системы API на другую (например, при смене ОС);
  • Потеря функциональности при переходе с более низкого уровня на более высокий. Грубо говоря, каждый «слой» API создаётся для облегчения выполнения некоторого стандартного набора операций. Но при этом реально затрудняется, либо становится принципиально невозможным выполнение некоторых других операций, которые предоставляет более низкий уровень API.

Наиболее известные API

Операционных систем

API (от англ. Application Program Interface) – это интерфейс взаимодействия между сайтом клиента и сервером. Представляет собой ресурс, который сервер открывает для работы извне, т.е. программист может воспользоваться им для получения доступа к функционалу программы, библиотеки, модуля. API делает возможным работу ресурсов, которые используют потенциал и мощность предоставляющего сайта, а также запуск дополнительных компонентов к ним, расширяющих возможности web-проекта.

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

Типы

  • возвращающие. На запрос стороннего приложения какого-либо метода с заданными параметрами сервер дает запрашиваемую информацию в определенном формате;
  • изменяющие. Клиент вызывает некоторую функцию сервера, которая вводит новую информацию или изменяет на нем определенные настройки.

API Яндекс.Директа

Для продвижения сайтов эффективен API .

  1. На его базе разработчики могут создавать приложения, которые напрямую взаимодействуют со службой поисковой системы. Такие программы позволят рекламодателям гибко управлять масштабными , получать статистические отчеты по каждой из них, точно прогнозировать бюджеты.
  2. Рекламные агентства с помощью API Директа могут просмотреть весь список своих клиентов, клиенты – представителей.
  3. Если определенные фразы, используемые для поисковой оптимизации , дают низкий CTR в контекстной рекламе, показ по ним можно автоматически отключить. На тематических площадках через API можно задавать ставки, определенные доноры могут быть удалены.
  4. API Яндекс.Директа имеет SOAP-интерфейс, т.е предоставляет широкий выбор языков программирования для создания приложений. Данный протокол поддерживается такими языками, как Perl, Java,

API (англ. Application Programming Interface ) - это интерфейс программирования приложений . API конкретного приложения или сервиса предоставляет набор готовых процедур, функций и переменных, с помощью которых сторонние разработчики могут создавать свои приложения и скрипты для работы с этим сервисом.

При работе через API приложение отправляет запрос к сервису и получает ответ, содержащий запрошенные данные, вне зависимости от того, на каком языке программирования они созданы.

Владельцы интернет-магазинов при помощи сторонних сервисов и собственных приложений имеют возможность обращаться по API к:

Информации об оформленных заказах

Доступные действия (методы) обработки информации о заказах:

  1. Выбор информации о заказе по ID
  2. Выбор информации о заказах по фильтру
  3. Количество заказов по фильтру
  4. Создание заказа
  5. Удаление заказа
  6. Массовое удаление заказов
  7. Выбор всех доступных статусов для заказов
  8. Обновление статуса заказа
  9. Добавление комментария к заказу

Информации о подписчиках

  1. Добавление подписчика
  2. Удаление подписчика
  3. Массовое удаление подписчиков
  4. Выбор данных о подписчиках по фильтру
  5. Количество подписчиков по фильтру

Информации о зарегистрированных пользователях

Доступные действия (методы) обработки информации о подписчиках:

  1. Выбор информации о зарегистрированных пользователях по ID
  2. Выбор информации обо всех зарегистрированных пользователях
  3. Выбор информации обо всех данных указанных пользователем при регистрации:
    • Фамилия, имя, отчество;
    • Контактный адрес электронной почты;
    • Контактный номер телефона;
    • Указанный адрес доставки: индекс, название населенного пункта, название улицы, номер дома, номер корпуса, номер квартиры, этаж;

Обратите внимание! При регистрации, пользователь может не заполнить все указанные выше поля.

Планы по развитию API

В ближайшее время, мы планируем открыть интерфейсы для поддержки взаимодействия магазинов со сторонними приложениями и сервисами по работе с:

  1. Разделами каталога.
  2. Товарами.
  3. Корзиной.
  4. Скидками.
  5. Способами доставки.
  6. Способами оплаты.

Для тестирования взаимодействия с API платформы beseller создан тестовый магазин beseller-api.shop.by .

Для доступа к тестовому магазину необходимо указать логин и пароль. Их вы можете получить по запросу у вашего персонального менеджера.

Перед тестированием взаимодействия с API мы рекомендуем вам:

  1. оформить самостоятельно несколько заказов;
  2. подписаться на рассылку;
  3. посмотреть как информация об оформленных заказах и подписчиках отображается в панели администрирования магазина.

Панель управления магазином доступна по адресу: beseller-api.shop.by/manager/ . Логин и пароль при входе в панель управления аналогичны логину и паролю доступа к магазину.

Как подключиться по API к своему магазину?

Для связи приложения с вашим магазином необходимо указать url-адрес доступа к API вида:

http://адрес_вашего_сайта:8082/graphql?token=ваш_персональный_секретный_ключ

Секретный ключ вы можете получить по запросу у вашего персонального менеджера.

Функции и переменные GraphQL для работы с API платформы beseller

Как подключиться к API с использованием языка программирования PHP

Для удобства работы с API платформы beseller вы можете воспользоваться:

  1. Классами разработанными нами под PHP.
    1. GraphqlClient - осуществляет прием и передачу данных на сервер;
    2. GraphQlHelper - содержит в себе реализованные query и mutation API;
  2. Примерами использования классов для осуществления выборок и изменений в базе данных интернет-магазина.

Настройка локального окружения

Для того, чтобы наглядно продемонстрировать отправку запросов к API и получаемые ответы, вы можете воспользоваться локальным окружением.

В качестве локального окружения используется GraphiQL Feen , это расширение для браузера Google Chrome которое позволяет формировать запросы к API.

После установки приложения у вас в браузере возле адресной строки появится иконка приложения.

Откройте приложение GraphiQL Feen и перейти на вкладку «SERVERS», выберите метод отправки POST, после чего укажите url-адрес доступа к API.

В качестве тестового url необходимо использовать следующий адрес:

Локальное окружение настроено, можно формировать запросы к API. Для этого необходимо открыть вкладку «QUERIES»

Формирование запроса к API beseller при помощи GraphiQL Feen и полученный ответ

Пояснения к скриншоту:

  1. Сохраненные запросы
  2. Поле для ввода запросов
  3. Поле ввода переменных
  4. Полученный ответ
  5. Кнопка запуска

Пример запроса на получение списка оформленных заказов за указанный промежуток времени

query ($first:Int, $offset:Int, $filter: OrdersFilterType){
orders(first:$first, offset:$offset, filter:$filter){
comment
status{
id
description
name
}
create_date
update_date
total {
suffix
value
}
payment {
name
description
cost {
suffix
value
}
}
delivery {
name
description
cost {
suffix
value
}
}
currencies {
bank_code
course
suffix
}
user_data {
name
description
value
}
}
}

Указание промежутка времени для выборки данных об оформленных заказах

{
"filter": {
"date_after": "2017-11-16T00:00:01Z",
"date_before": "2017-11-23T00:00:01Z"
}
}

Пример ответа от API

{{
"data": {
"orders": [
{
"comment": "Culpa officiis vel ut.",
"create_date": "2017-11-22 16:23:28",
"currencies": [
{
"bank_code": "BYN",
"course": 10000,
"suffix": "руб."
}
],
"delivery": {
"cost": [
{
"suffix": "руб.",
"value": 0
}
],
"description": "Курьер",
"name": "custom"
},
"payment": {
"cost": [
{
"suffix": "руб.",
"value": 0
}
],
"description": "Пластиковые карты",
"name": "custom"
},
"status": {
"description": "Новый",
"id": 1,
"name": "new"
},
"total": [
{
"suffix": "руб.",
"value": 4450
}
],
"update_date": "2017-11-22 16:23:28",
"user_data": [
{
"description": "Адрес e-mail",
"name": "email",
"value": "[email protected]"
},
{
"description": "Телефон",
"name": "phone",
"value": "784.392.3949 x69329"
},
{
"description": "Адрес",
"name": "registration",
"value": "607 Erik Station Suite 057\nReynaberg, WY 83542-0037"
},
{
"description": "Комментарий",
"name": "comment",
"value": "Id nam illo optio."
},
{
"description": "ФИО",
"name": "fio",
"value": "Jordi Mann MD"
}
]
}