Como restringir o acesso à API com as chaves de API

Use as chaves da API para restringir o acesso a métodos específicos ou a todos os métodos em uma API. Nesta página, você aprende a restringir o acesso à API para os clientes com uma chave, além de criar uma chave de API.

Se você definir um requisito de chave na sua API, as solicitações para métodos, classes ou APIs protegidas serão rejeitadas a menos que elas tenham uma chave gerada no seu projeto ou em outros projetos de desenvolvedores com acesso para ativar sua API . O projeto em que a chave de API foi criada não é registrado nem adicionado ao cabeçalho da solicitação. No entanto, é possível visualizar o projeto Google Cloud a que um cliente está associado na página Serviços do Endpoints, conforme descrito em Filtrar por um projeto específico de consumidor.

Para mais informações sobre em qual Google Cloud projeto uma chave de API precisa ser criada, consulte Como compartilhar APIs protegidas por chaves.

Como restringir acesso a todos os métodos da API

Para exigir o uso de uma chave de API para todas as chamadas na API, adicione apiKeyRequired = AnnotationBoolean.TRUE à anotação @Api . Por exemplo:

@Api(
  name = "echo",
  version = "v1",
  apiKeyRequired = AnnotationBoolean.TRUE
  )
public class Echo {
//API class and methods...
}

Restrição de acesso a métodos específicos da API

Para exigir o uso de uma chave de API em todas as chamadas para um método de API específico, adicione apiKeyRequired = AnnotationBoolean.TRUE à sua anotação @ApiMethod. Exemplo:

@ApiMethod(name = "echo_api_key", path = "echo_api_key", apiKeyRequired = AnnotationBoolean.TRUE)
public Message echoApiKey(Message message, @Named("n") @Nullable Integer n) {
  return doEcho(message, n);
}

Para exigir o uso de uma chave de API em todas as chamadas para uma classe específica da API, adicione apiKeyRequired = AnnotationBoolean.TRUE à anotação @ApiClass.

Como remover a restrição de chave de API de um método

Para desativar a validação da chave em uma API ou um método de API, remova api_key_required=True (Python) ou apiKeyRequired = AnnotationBoolean.TRUE (Java) da API, do decorador do método ou da anotação. Em seguida, faça a compilação e a implantação novamente.

Como chamar uma API usando uma chave de API

Se uma API ou método de API exigir uma chave, forneça uma usando um parâmetro de consulta chamado key, como mostrado neste exemplo de cURL:

curl \
    -H "Content-Type: application/json" \
    -X POST \
    -d '{"message": "echo"}' \
    "${HOST}/_ah/api/echo/v1/echo_api_key?key=${API_KEY}"

em que HOST e API_KEY são variáveis que contêm o nome de host da API e a chave de API, respectivamente. Substitua echo pelo nome e v1 pela versão da API.

Como compartilhar APIs protegidas por chaves

As chaves de API são associadas ao projeto Google Cloud em que foram criadas. Se você decidiu exigir uma chave para sua API, o projeto do Google Cloud em que a chave de API é criada depende das respostas às seguintes perguntas:

  • Você precisa diferenciar os chamadores de sua API para poder usar recursos do Endpoints, como cotas?
  • Todos os autores das chamadas da API têm os próprios projetos do Google Cloud ?
  • Você precisa configurar diferentes restrições de chave de API?

Use a árvore de decisões abaixo como guia para decidir em qual projeto do Google Cloud criar a chave de API.

Árvore de decisão de chave de API

Conceder permissão para ativar a API

Quando você precisa distinguir os autores das chamadas da API e cada um deles tem um projeto do Google Cloud próprio, é possível conceder permissão aos principais para ativar a API no próprio projeto do Google Cloud . Dessa forma, os usuários da API podem criar a própria chave para usar com ela.

Por exemplo, digamos que sua equipe tenha criado uma API para uso interno por diversos programas cliente na empresa e cada um deles tenha o próprio projeto do Google Cloud. Para diferenciar os autores das chamadas da API, a chave de cada um deles precisa ser criada em um projeto diferente do Google Cloud . Dê permissão para que seus colegas ativem a API no projeto Google Cloud ao qual o programa cliente está associado.

Veja como permitir que os usuários criem a própria chave de API:

  1. No Google Cloud projeto em que a API está configurada, conceda a cada usuário a permissão para ativar a API.
  2. Entre em contato com os usuários para informar que eles podem ativar a API no projeto do Google Cloud e criar uma chave de API.

Crie um projeto Google Cloud separado para cada autor da chamada

Quando você precisa diferenciar os autores das chamadas da API, mas nem todos têm projetos do Google Cloud , crie um projeto Google Cloud e uma chave de API separados para cada autor. Antes de criar os projetos, pense nos nomes deles para facilitar a identificação do cliente associado a cada um.

Por exemplo, digamos que você tenha clientes externos da API e não tenha ideia de como foram criados os programas clientes que chamam essa API. Talvez alguns dos clientes usem Google Cloud e tenham um Google Cloud projeto, e talvez outros não. Para diferenciar os autores das chamadas, crie um projeto no Google Cloud e uma chave de API separados para cada autor.

Para criar um projeto Google Cloud e uma chave de API separados para cada autor da chamada:

  1. Crie um projeto separado para cada autor da chamada.
  2. Em cada projeto, ative a API e crie uma chave de API.
  3. Forneça a chave de API para cada autor da chamada.

Criar uma chave de API para cada autor da chamada

Quando você não precisa distinguir entre os autores das chamadas de API, mas quer adicionar restrições de chave de API, é possível criar uma chave de API separada para cada autor da chamada no mesmo projeto.

Veja como criar uma chave de API para cada autor da chamada no mesmo projeto:

  1. No projeto em que a API estiver ativada ou configurada, crie uma chave de API para cada cliente com as restrições necessárias.
  2. Forneça a chave de API para cada autor da chamada.

Criar uma chave de API para todos os autores das chamadas

Quando você não precisa distinguir entre os autores das chamadas de API e não precisa adicionar restrições, mas ainda quer exigir uma chave de API (para impedir o acesso anônimo, por exemplo), é possível criar uma chave para todos os autores de chamadas usarem.

Veja como criar uma chave de API para todos os autores das chamadas:
  1. No projeto em que a API estiver ativada ou configurada, crie uma chave de API para todos os autores das chamadas.
  2. Forneça a mesma chave de API para cada autor da chamada.

A seguir