Вы просматриваете документацию Apigee Edge .
Перейти к документации Apigee X. info

Что
Политика проверки ключей API позволяет принудительно проверять ключи API во время выполнения, предоставляя доступ к вашим API только приложениям с одобренными ключами. Эта политика гарантирует, что ключи API действительны, не отозваны и одобрены для использования определённых ресурсов, связанных с вашими продуктами API.
Образцы
Введите параметр запроса
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="request.queryparam.apikey" /> </VerifyAPIKey>
В этом примере политика ожидает найти ключ API в переменной потока с именем request.queryparam.apikey
. Переменная request.queryparam.{name}
— это стандартная переменная потока Edge, которая заполняется значением параметра запроса, переданного в клиентском запросе.
Следующая команда curl
передает ключ API в параметре запроса:
curl http://myorg-test.apigee.net/mocktarget?apikey=IEYRtW2cb7A5Gs54A1wKElECBL65GVls
Введите заголовок
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="request.header.x-apikey" /> </VerifyAPIKey>
В этом примере политика ожидает найти ключ API в переменной потока с именем request.header.x-apikey
. Переменная request.header.{name}
— это стандартная переменная потока Edge, которая заполняется значением заголовка, переданного в клиентском запросе.
Следующий cURL показывает, как передать ключ API в заголовке:
curl "http://myorg-test.apigee.net/mocktarget" -H "x-apikey:IEYRtW2cb7A5Gs54A1wKElECBL65GVls"
Введите переменную
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="requestAPIKey.key"/> </VerifyAPIKey>
Политика может ссылаться на любую переменную, содержащую ключ. В этом примере политика извлекает ключ API из переменной с именем requestAPIKey.key .
Способ заполнения этой переменной зависит от вас. Например, вы можете использовать политику Extract Variables для заполнения requestAPIKey.key из параметра запроса myKey , как показано ниже:
<ExtractVariables async="false" continueOnError="false" enabled="true" name="SetAPIKeyVar"> <Source>request</Source> <QueryParam name="myKey"> <Pattern ignoreCase="true">{key}</Pattern> </QueryParam> <VariablePrefix>requestAPIKey</VariablePrefix> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> </ExtractVariables>
Переменные потока политики доступа
<AssignMessage async="false" continueOnError="false" enabled="true" name="accessverifyvars"> <AssignVariable> <Name>devFirstName</Name> <Ref>verifyapikey.verify-api-key.developer.firstName</Ref> <Value>ErrorOnCopy</Value> </AssignVariable> <AssignVariable> <Name>devLastName</Name> <Ref>verifyapikey.verify-api-key.developer.lastName</Ref> <Value>ErrorOnCopy</Value> </AssignVariable> <AssignVariable> <Name>devEmail</Name> <Ref>verifyapikey.verify-api-key.developer.email</Ref> <Value>ErrorOnCopy</Value> </AssignVariable> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </AssignMessage>
Edge автоматически заполняет набор переменных потока при выполнении политики проверки ключа API для действительного ключа API. Эти переменные можно использовать для доступа к такой информации, как название приложения, идентификатор приложения, а также информация о разработчике или компании, зарегистрировавшей приложение. В приведенном выше примере политика назначения сообщения используется для доступа к имени, фамилии и адресу электронной почты разработчика после выполнения политики проверки ключа API.
Все эти переменные имеют префикс:
verifyapikey.{policy_name}
В этом примере политика API-ключа проверки называется « verify-api-key ». Поэтому вы ссылаетесь на имя разработчика, отправившего запрос, используя переменную verifyapikey.verify-api-key.developer.firstName.
Изучите Edge
О политике проверки ключа API
Когда разработчик регистрирует приложение в Edge, Edge автоматически генерирует пару «ключ потребителя» и «секрет». Вы можете увидеть пару «ключ потребителя» и «секрет» приложения в пользовательском интерфейсе Edge или получить к ним доступ через Edge API.
При регистрации приложения разработчик выбирает один или несколько API-продуктов для связи с приложением. API-продукт — это набор ресурсов, доступных через прокси-серверы API. Затем разработчик передаёт ключ API (ключ потребителя) в каждом запросе к API-продукту, связанному с приложением. Подробнее см. в разделе «Обзор публикации» .
Ключи API можно использовать в качестве токенов аутентификации или для получения токенов доступа OAuth. В OAuth ключи API называются «идентификаторами клиента». Эти названия взаимозаменяемы. Подробнее см. на главной странице OAuth .
Edge автоматически заполняет набор переменных потока при выполнении политики проверки ключа API. Подробнее см. в разделе «Переменные потока» ниже.
Ссылка на элемент
Ниже приведены элементы и атрибуты, которые можно настроить в этой политике:
<VerifyAPIKey async="false" continueOnError="false" enabled="true" name="Verify-API-Key-1"> <DisplayName>Custom label used in UI</DisplayName> <APIKey ref="variable_containing_api_key"/> </VerifyAPIKey>
Атрибуты <VerifyAPIKey>
В следующем примере показаны атрибуты тега <VerifyAPIKey>
:
<VerifyAPIKey async="false" continueOnError="false" enabled="true" name="Verify-API-Key-1">
В следующей таблице описаны атрибуты, общие для всех родительских элементов политики:
Атрибут | Описание | По умолчанию | Присутствие |
---|---|---|---|
name | Внутреннее имя политики. Значение атрибута При необходимости используйте элемент | Н/Д | Необходимый |
continueOnError | Установите значение Установите значение | ЛОЖЬ | Необязательный |
enabled | Установите значение Установите значение | истинный | Необязательный |
async | Этот атрибут устарел. | ЛОЖЬ | Устарело |
Элемент <DisplayName>
Используйте в дополнение к атрибуту name
, чтобы пометить политику в редакторе прокси-сервера пользовательского интерфейса управления другим именем на естественном языке.
<DisplayName>Policy Display Name</DisplayName>
По умолчанию | Н/Д Если вы опустите этот элемент, будет использовано значение атрибута |
---|---|
Присутствие | Необязательный |
Тип | Нить |
Элемент <APIKey>
Этот элемент определяет переменную потока, содержащую ключ API. Обычно клиент отправляет ключ API в параметре запроса, HTTP-заголовке или параметре формы. Например, если ключ отправляется в заголовке x-apikey
, он будет найден в переменной request.header.x-apikey
По умолчанию | NA |
---|---|
Присутствие | Необходимый |
Тип | Нить |
Атрибуты
В следующей таблице описаны атрибуты элемента <APIKey>
Атрибут | Описание | По умолчанию | Присутствие |
---|---|---|---|
реф | Ссылка на переменную, содержащую ключ API. Для каждой политики допускается только одно расположение. | Н/Д | Необходимый |
Примеры
В этих примерах ключ передается в параметрах и заголовке, называемом x-apikey
.
В качестве параметра запроса:
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="request.queryparam.x-apikey"/> </VerifyAPIKey>
В качестве HTTP-заголовка:
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="request.header.x-apikey"/> </VerifyAPIKey>
В качестве параметра HTTP-формы:
<VerifyAPIKey name="APIKeyVerifier"> <APIKey ref="request.formparam.x-apikey"/> </VerifyAPIKey>
Схемы
Переменные потока
Когда политика проверки ключа API применяется к действительному ключу API, Edge заполняет набор переменных потока. Эти переменные доступны политикам или коду, выполняемому позже в потоке, и часто используются для выполнения пользовательской обработки на основе атрибутов ключа API, таких как имя приложения, API-продукт, используемый для авторизации ключа, или настраиваемых атрибутов ключа API.
Политика заполняет несколько различных типов переменных потока, включая:
- Общий
- Приложение
- Разработчик
- Компания
- Аналитика
Каждый тип переменной потока имеет свой префикс. Все переменные являются скалярами, за исключением тех, которые специально обозначены как массивы.
Общие переменные потока
В следующей таблице перечислены общие переменные потока, заполняемые политикой проверки ключа API. Все эти переменные имеют префикс:
verifyapikey.{policy_name}
Например: verifyapikey.{policy_name}.client_id
Доступные переменные включают:
Переменная | Описание |
---|---|
client_id | Ключ потребителя (он же ключ API или ключ приложения), предоставленный запрашивающим приложением. |
client_secret | Секрет потребителя, связанный с ключом потребителя. |
redirection_uris | Любые URI перенаправления в запросе. |
developer.app.id | Идентификатор приложения разработчика, сделавшего запрос. |
developer.app.name | Имя приложения разработчика, сделавшего запрос. |
developer.id | Идентификатор разработчика, зарегистрированного как владелец запрашивающего приложения. |
developer.{custom_attrib_name} | Любые пользовательские атрибуты, полученные из профиля ключа приложения |
DisplayName | Значение атрибута <DisplayName> политики. |
failed | Установите значение «true», если проверка ключа API не пройдена. |
{custom_app_attrib} | Любой настраиваемый атрибут, полученный из профиля приложения. Укажите имя настраиваемого атрибута. |
apiproduct.name* | Название продукта API, используемого для проверки запроса. |
apiproduct.{custom_attrib_name}* | Любой пользовательский атрибут, полученный из профиля продукта API. |
apiproduct.developer.quota.limit* | Установленный лимит квоты для продукта API, если таковой имеется. |
apiproduct.developer.quota.interval* | Интервал квоты, установленный для продукта API, если таковой имеется. |
apiproduct.developer.quota.timeunit* | Единица времени квоты, установленная для продукта API, если таковая имеется. |
* Переменные API-продуктов заполняются автоматически, если для API-продуктов настроены допустимые среда, прокси-серверы и ресурсы (полученные из proxy.pathsuffix ). Инструкции по настройке API-продуктов см. в разделе «Использование API управления Edge для публикации API» . |
Переменные потока приложения
Политика заполняет следующие переменные потока, содержащие информацию о приложении. Все эти переменные имеют префикс:
verifyapikey.{policy_name}.app
.
Например:
verifyapikey.{policy_name}.app.name
Доступные переменные включают:
Переменная | Описание |
---|---|
name | Название приложения. |
id | Идентификатор приложения. |
accessType | Не используется Apigee. |
callbackUrl | URL обратного вызова приложения. Обычно используется только для OAuth. |
DisplayName | Отображаемое имя приложения. |
status | Статус приложения, например «одобрено» или «отозвано». |
apiproducts | Массив, содержащий список продуктов API, связанных с приложением. |
appFamily | Любое семейство приложений, содержащее приложение, или «по умолчанию». |
appParentStatus | Статус родительского приложения, например «активно» или «неактивно». |
appType | Тип приложения: «Компания» или «Разработчик». |
appParentId | Идентификатор родительского приложения. |
created_at | Дата/время создания приложения. |
created_by | Адрес электронной почты разработчика, создавшего приложение. |
last_modified_at | Дата/время последнего обновления приложения. |
last_modified_by | Адрес электронной почты разработчика, который последним обновил приложение. |
{app_custom_attributes} | Любой настраиваемый атрибут приложения. Укажите имя настраиваемого атрибута. |
Переменные потока разработчика
Политика заполняет следующие переменные потока, содержащие информацию о разработчике. Все эти переменные имеют префикс:
verifyapikey.{policy_name}.developer
Например:
verifyapikey.{policy_name}.developer.id
Доступные переменные включают:
Переменная | Описание |
---|---|
id | Возвращает {org_name}@@@{developer_id} |
userName | Имя пользователя разработчика. |
firstName | Имя разработчика. |
lastName | Фамилия разработчика. |
email | Адрес электронной почты разработчика. |
status | Статус разработчика: активный, неактивный или login_lock. |
apps | Массив приложений, связанных с разработчиком. |
created_at | Отметка даты/времени создания разработчика. |
created_by | Адрес электронной почты пользователя, создавшего разработчика. |
last_modified_at | Дата/время последнего изменения разработчика. |
last_modified_by | Адрес электронной почты пользователя, который изменил разработчика. |
{developer_custom_attributes} | Любой настраиваемый атрибут разработчика. Укажите имя настраиваемого атрибута. |
Company | Название компании, связанной с разработчиком, если таковая имеется. |
Переменные потока компании
Политика заполняет следующие переменные потока, содержащие информацию о компании. Все эти переменные имеют префикс:
verifyapikey.{policy_name}.company
Например:
verifyapikey.{policy_name}.company.name
Доступные переменные включают:
Переменная | Описание |
---|---|
name | Название компании. |
displayName | Отображаемое название компании. |
id | Идентификатор компании. |
apps | Массив, содержащий список приложений компании. |
appOwnerStatus | Статус владельца приложения: активное, неактивное или login_lock. |
created_at | Дата/время создания компании. |
created_by | Адрес электронной почты пользователя, создавшего компанию. |
last_modified_at | Дата/время последнего изменения компании. |
last_modified_by | Адрес электронной почты пользователя, который последним изменил компанию. |
{company_custom_attributes} | Любой настраиваемый атрибут компании. Укажите название настраиваемого атрибута. |
Аналитические переменные
Следующие переменные автоматически заполняются в Аналитике при применении политики проверки ключа API для действительного ключа API. Эти переменные заполняются только политикой проверки ключа API и политиками OAuth.
Переменные и значения можно использовать в качестве измерений для создания аналитических отчетов, чтобы получить представление о моделях потребления разработчиками и приложениями.
- apiproduct.name
- имя.разработчика.приложения
- клиент_идентификатор
- разработчик.id
Ссылка на ошибку
This section describes the fault codes and error messages that are returned and fault variables that are set by Edge when this policy triggers an error. This information is important to know if you are developing fault rules to handle faults. To learn more, see What you need to know about policy errors and Handling faults.
Runtime errors
These errors can occur when the policy executes.
Fault code | HTTP status | Cause |
---|---|---|
keymanagement.service.CompanyStatusNotActive |
401 | The Company associated with the Developer App that has the API key you are using has an inactive status. When a Company's status is set to inactive, you cannot access the developers or apps associated with that Company. An org admin can change a Company's status using the management API. See Set the Status of a Company. |
keymanagement.service.DeveloperStatusNotActive |
401 |
The developer who created the Developer App that has the API key you are using has an inactive status. When an App Developer's status is set to inactive, any Developer Apps created by that developer are deactivated. An admin user with appropriate permissions (such as Organization Administrator) can change a developer's status in the following ways:
|
keymanagement.service.invalid_client-app_not_approved |
401 | The Developer App associated with the API key is revoked. A revoked app cannot access any API products and cannot invoke any API managed by Apigee Edge. An org admin can change the status of a Developer App using the management API. See Approve or Revoke Developer App. |
oauth.v2.FailedToResolveAPIKey |
401 | The policy expects to find the API key in a variable that is specified in the policy's <APIKey> element. This error arises when the expected variable does not exist (it cannot be resolved). |
oauth.v2.InvalidApiKey |
401 | An API key was received by Edge, but it is invalid. When Edge looks up the key in its database, it must exactly match the on that was sent in the request. If the API worked previously, make sure the key was not regenerated. If the key was regenerated, you will see this error if you try to use the old key. For details, see Register apps and manage API keys. |
oauth.v2.InvalidApiKeyForGivenResource |
401 | An API key was received by Edge, and it is valid; however, it does not match an approved key in the Developer App associated with your API proxy through a Product. |
Deployment errors
These errors can occur when you deploy a proxy containing this policy.
Error name | Cause |
---|---|
SpecifyValueOrRefApiKey |
The <APIKey> element does not have a value or key specified. |
Fault variables
These variables are set when a runtime error occurs. For more information, see What you need to know about policy errors.
Variables | Where | Example |
---|---|---|
fault.name="fault_name" |
fault_name is the name of the fault, as listed in the Runtime errors table above. The fault name is the last part of the fault code. | fault.name Matches "FailedToResolveAPIKey" |
oauthV2.policy_name.failed |
policy_name is the user-specified name of the policy that threw the fault. | oauthV2.VK-VerifyAPIKey.failed = true |
Example error responses
{ "fault":{ "faultstring":"Invalid ApiKey", "detail":{ "errorcode":"oauth.v2.InvalidApiKey" } } }
{ "fault":{ "detail":{ "errorcode":"keymanagement.service.DeveloperStatusNotActive" }, "faultstring":"Developer Status is not Active" } }
Example fault rule
<FaultRule name="FailedToResolveAPIKey"> <Step> <Name>AM-FailedToResolveAPIKey</Name> </Step> <Condition>(fault.name Matches "FailedToResolveAPIKey") </Condition> </FaultRule>