Google consiglia vivamente di non inserire una chiave API nel sistema di controllo della versione. Devi invece archiviarla in un file secrets.properties
locale, che si trova nella directory principale del progetto, ma escluso dal controllo della versione, quindi
utilizzare il plug-in Secrets Gradle per Android
per leggere la chiave API.
Il plug-in Secrets Gradle per Android legge i secret, inclusa la chiave API, da un file di proprietà non sottoposto a controllo in un sistema di controllo della versione. Il plug-in espone quindi queste proprietà come variabili nella classe BuildConfig
generata da Gradle e nel file manifest di Android.
Per un esempio completo dell'utilizzo del plug-in Secrets Gradle per Android per accedere a una chiave API, consulta Configurare un progetto Android Studio.
Installazione e utilizzo
Per installare il plug-in Secrets Gradle per Android nel tuo progetto Google Maps:
-
In Android Studio, apri il file
build.gradle.kts
obuild.gradle
di primo livello e aggiungi il seguente codice all'elementodependencies
inbuildscript
.Kotlin
buildscript { dependencies { classpath("com.google.android.libraries.mapsplatform.secrets-gradle-plugin:secrets-gradle-plugin:2.0.1") } }
Trendy
buildscript { dependencies { classpath "com.google.android.libraries.mapsplatform.secrets-gradle-plugin:secrets-gradle-plugin:2.0.1" } }
-
Apri il file
build.gradle.kts
obuild.gradle
a livello di modulo e aggiungi il seguente codice all'elementoplugins
.Kotlin
plugins { // ... id("com.google.android.libraries.mapsplatform.secrets-gradle-plugin") }
Trendy
plugins { // ... id 'com.google.android.libraries.mapsplatform.secrets-gradle-plugin' }
- Nel file
build.gradle.kts
obuild.gradle
a livello di modulo, assicurati chetargetSdk
ecompileSdk
siano impostati su 34. - Sincronizza il progetto con Gradle.
-
Apri il file
secrets.properties
nella directory di primo livello e aggiungi il codice seguente. SostituisciYOUR_API_KEY
con la tua chiave API. Memorizza la chiave in questo file perchésecrets.properties
è esclusa dal controllo in un sistema di controllo delle versioni.MAPS_API_KEY=YOUR_API_KEY
-
Crea il file
local.defaults.properties
nella directory di primo livello, nella stessa cartella del filesecrets.properties
, quindi aggiungi il codice seguente.MAPS_API_KEY=DEFAULT_API_KEY
Lo scopo di questo file è fornire una posizione di backup per la chiave API se il file
secrets.properties
non viene trovato, in modo che le build non falliscano. Questo può accadere se cloni l'app da un sistema di controllo della versione che omettesecrets.properties
e non hai ancora creato un filesecrets.properties
localmente per fornire la tua chiave API. -
Nel file
AndroidManifest.xml
, vai acom.google.android.geo.API_KEY
e aggiornaandroid:value attribute
. Se il tag<meta-data>
non esiste, creane uno come elemento secondario del tag<application>
.<meta-data android:name="com.google.android.geo.API_KEY" android:value="${MAPS_API_KEY}" />
Nota:
com.google.android.geo.API_KEY
è il nome dei metadati consigliato per la chiave API. Una chiave con questo nome può essere utilizzata per autenticarsi in più API basate su Google Maps sulla piattaforma Android, incluso Maps SDK for Android. Per la compatibilità con le versioni precedenti, l'API supporta anche il nomecom.google.android.maps.v2.API_KEY
. Questo nome legacy consente l'autenticazione solo all'API Android Maps v2. Un'applicazione può specificare solo uno dei nomi dei metadati della chiave API. Se vengono specificati entrambi, l'API genera un'eccezione. -
In Android Studio, apri il file
build.gradle.kts
obuild.gradle
a livello di modulo e modifica la proprietàsecrets
. Se la proprietàsecrets
non esiste, aggiungila.Modifica le proprietà del plug-in per impostare
propertiesFileName
susecrets.properties
,defaultPropertiesFileName
sulocal.defaults.properties
e altre proprietà.Kotlin
secrets { // To add your Maps API key to this project: // 1. If the secrets.properties file does not exist, create it in the same folder as the local.properties file. // 2. Add this line, where YOUR_API_KEY is your API key: // MAPS_API_KEY=YOUR_API_KEY propertiesFileName = "secrets.properties" // A properties file containing default secret values. This file can be // checked in version control. defaultPropertiesFileName = "local.defaults.properties" }
Trendy
secrets { // To add your Maps API key to this project: // 1. If the secrets.properties file does not exist, create it in the same folder as the local.properties file. // 2. Add this line, where YOUR_API_KEY is your API key: // MAPS_API_KEY=YOUR_API_KEY propertiesFileName = "secrets.properties" // A properties file containing default secret values. This file can be // checked in version control. defaultPropertiesFileName = "local.defaults.properties" }
Passaggi successivi
- Visualizza la pagina del progetto GitHub del plug-in Secrets Gradle per Android.
- Consulta Configurare un progetto Android Studio per un esempio completo dell'utilizzo del plug-in.