La maggior parte delle risorse Google Cloud espongono il metodo testIamPermissions()
, che
ti consente di controllare in modo programmatico
se il chiamante attualmente autenticato
sono state concesse una o più autorizzazioni IAM specifiche
risorsa. Il metodo testIamPermissions()
accetta un identificatore di risorsa e un
di autorizzazioni come parametri di input e restituisce l'insieme di autorizzazioni
l'utente può chiamarli.
Puoi utilizzare il metodo testIamPermissions()
per determinare se un utente deve avere accesso a uno strumento amministrativo in un'applicazione web. Ad esempio, puoi
usa questo metodo per decidere, in base alle autorizzazioni dell'utente, se visualizzare
informazioni dettagliate su una risorsa Google Cloud.
Ad esempio, per determinare se l'utente attualmente autenticato dispone dell'autorizzazione
per eliminare un progetto, richiama
projects.testIamPermissions()
fornendo l'ID progetto (ad esempio foo-project
) e il metodo
Autorizzazione resourcemanager.projects.delete
come parametri di input. Se il chiamante
ha ricevuto l'autorizzazione resourcemanager.projects.delete
, verrà
elencato nel corpo della risposta. Se il chiamante non dispone di questa autorizzazione,
il corpo della risposta non elencherà nessuna autorizzazione.
Il metodo testIamPermissions()
è destinato a grafica di terze parti
interfacce utente (GUI) che devono visualizzare le risorse Google Cloud basate
ai dati che l'utente autenticato è autorizzato a visualizzare. Ad esempio, la console Google Cloud utilizza internamente il metodo testIamPermissions()
per determinare quali risorse e funzionalità sono visibili dopo l'autenticazione. In genere, a utenti diversi vengono concesse autorizzazioni diverse e la console Google Cloud nasconde o mostra gli elementi di conseguenza.
Prima di iniziare
Enable the Resource Manager API.
Configurare l'autenticazione.
Select the tab for how you plan to use the samples on this page:
C++
Per utilizzare gli C++ esempi in questa pagina in una località dell'ambiente di sviluppo, installare e inizializzare gcloud CLI quindi configura Credenziali predefinite dell'applicazione con le tue credenziali utente.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
Per ulteriori informazioni, vedi Configurare l'autenticazione per un ambiente di sviluppo locale nella documentazione sull'autenticazione di Google Cloud.
C#
Per utilizzare gli .NET esempi in questa pagina in una località dell'ambiente di sviluppo, installare e inizializzare gcloud CLI quindi configura Credenziali predefinite dell'applicazione con le tue credenziali utente.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
Per ulteriori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale nella documentazione sull'autenticazione di Google Cloud.
Java
Per utilizzare gli Java esempi in questa pagina in un ambiente di sviluppo locale, installa e inizializza l'interfaccia a riga di comando gcloud, quindi configura le credenziali predefinite dell'applicazione con le tue credenziali utente.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
Per ulteriori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale nella documentazione sull'autenticazione di Google Cloud.
Python
Per utilizzare gli Python esempi in questa pagina in un ambiente di sviluppo locale, installa e inizializza l'interfaccia a riga di comando gcloud, quindi configura le credenziali predefinite dell'applicazione con le tue credenziali utente.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
Per ulteriori informazioni, vedi Configurare l'autenticazione per un ambiente di sviluppo locale nella documentazione sull'autenticazione di Google Cloud.
REST
Per utilizzare gli esempi dell'API REST in questa pagina in un ambiente di sviluppo locale, utilizza le credenziali fornite a gcloud CLI.
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
Per ulteriori informazioni, vedi Esegui l'autenticazione per l'utilizzo di REST nella documentazione sull'autenticazione di Google Cloud.
Ruoli obbligatori
Non è necessario alcun ruolo IAM per testare le autorizzazioni.
Come testare le autorizzazioni
Questo esempio mostra come testare
resourcemanager.projects.get
e Autorizzazioniresourcemanager.projects.delete
per progetto Google Cloud. A le autorizzazioni di test per altre risorse Google Cloud, utilizza MetodotestIamPermissions()
esposto da ogni risorsa. Ad esempio, puoi testare le autorizzazioni IAM per Bucket Cloud Storage.C++
Per scoprire come installare e utilizzare la libreria client per IAM, consulta Librerie client IAM. Per ulteriori informazioni, consulta API IAM C++ documentazione di riferimento.
Per autenticarti in IAM, configura le credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Prima di iniziare.
C#
Per eseguire l'autenticazione su Resource Manager, configura le credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Prima di iniziare.
Per scoprire come installare e utilizzare la libreria client per Resource Manager, vedi Client Resource Manager librerie.
IAM verifica le autorizzazioni dell'account di servizio che utilizzate per generare le credenziali.
Java
Per eseguire l'autenticazione su Resource Manager, configura le credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Prima di iniziare.
Per scoprire come installare e utilizzare la libreria client per Resource Manager, vedi Client Resource Manager librerie.
IAM verifica le autorizzazioni dell'account di servizio che utilizzate per generare le credenziali.
Python
Per eseguire l'autenticazione su Resource Manager, configura le credenziali predefinite dell'applicazione. Per ulteriori informazioni, consulta Prima di iniziare.
Per scoprire come installare e utilizzare la libreria client per Resource Manager, vedi Client Resource Manager librerie.
IAM verifica le autorizzazioni dell'account di servizio che utilizzate per generare le credenziali.
REST
In questo esempio, l'utente ha un ruolo IAM che gli consente di per ottenere informazioni su un progetto, ma non per eliminarlo.
L'API Resource Manager
projects.testIamPermissions
accetta un elenco di autorizzazioni e verifica di quali autorizzazioni dispone un'entità.Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
PROJECT_ID
: il tuo progetto Google Cloud ID. Gli ID progetto sono stringhe alfanumeriche, ad esempiomy-project
.
Metodo HTTP e URL:
POST https://cloudresourcemanager.googleapis.com/v1/projects/PROJECT_ID:testIamPermissions
Corpo JSON della richiesta:
{ "permissions": [ "resourcemanager.projects.get", "resourcemanager.projects.delete" ] }
Per inviare la richiesta, espandi una delle seguenti opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "permissions": [ "resourcemanager.projects.get" ] }
Passaggi successivi
Scopri come concedere, modificare e revocare l'accesso alle entità.
Salvo quando diversamente specificato, i contenuti di questa pagina sono concessi in base alla licenza Creative Commons Attribution 4.0, mentre gli esempi di codice sono concessi in base alla licenza Apache 2.0. Per ulteriori dettagli, consulta le norme del sito di Google Developers. Java è un marchio registrato di Oracle e/o delle sue consociate.
Ultimo aggiornamento 2024-10-14 UTC.