Cloud Storage for Firebase ti consente di caricare e condividere contenuti generati dagli utenti, come immagini e video, in modo da poter integrare contenuti multimediali avanzati nelle tue app. I dati vengono archiviati in un Google Cloud Storage bucket, una soluzione di archiviazione di oggetti su scala exabyte con elevata affidabilità e ridondanza globale. Cloud Storage for Firebase ti consente di caricare in sicurezza questi file direttamente da dispositivi mobili e browser web, gestendo facilmente le reti instabili con facilità.
Prima di iniziare
Prima di poter utilizzare Cloud Storage, devi:
Registrare il progetto C++ e configurarlo per l'utilizzo di Firebase.
Se il tuo progetto C++ utilizza già Firebase, è già registrato e configurato per Firebase.
Aggiungere Firebase C++ SDK al progetto C++.
Tieni presente che l'aggiunta di Firebase al progetto C++ comporta attività sia nella Firebase console sia nel progetto C++ aperto (ad esempio, scarichi i file di configurazione di Firebase dalla console, quindi li sposti nel progetto C++).
Inoltre, assicurati che il tuo progetto Firebase utilizzi il piano tariffario Blaze con pagamento a consumo, un requisito introdotto a ottobre 2024 (consulta le nostre Domande frequenti). Se non hai familiarità con Firebase e Google Cloud, verifica se hai diritto a un credito di 300$.
Creare un bucket predefinitoCloud Storage
Nel riquadro di navigazione della Firebase console, seleziona Storage.
Se il tuo progetto non utilizza ancora il piano tariffario Blaze con pagamento a consumo, ti verrà chiesto di eseguire l'upgrade.
Fai clic su Inizia.
Seleziona una località per il bucket predefinito.
I bucket in
,US-CENTRAL1 eUS-EAST1 possono usufruire del "Sempre senza costi" livello per Google Cloud Storage. I bucket in tutte le altre località seguono Google Cloud Storage prezzi e utilizzo.US-WEST1Se vuoi, puoi creare più bucket in un secondo momento, ognuno con la propria località.
Configura il Firebase Security Rules per il bucket predefinito. Durante lo sviluppo, valuta la possibilità di configurare le regole per l'accesso pubblico.
Fai clic su Fine.
Ora puoi visualizzare il bucket nella
Cloud Storage scheda
della Firebase console. Il formato del nome del bucket predefinito è
PROJECT_ID.firebasestorage.app
Configurare l'accesso pubblico
Cloud Storage for Firebase fornisce un linguaggio di regole dichiarative che ti consente di definire la struttura dei dati, la modalità di indicizzazione e quando i dati possono essere letti e scritti. Per impostazione predefinita, l'accesso in lettura e scrittura a Cloud Storage è limitato, quindi solo gli utenti autenticati possono leggere o scrivere dati. Per iniziare senza configurare Authentication, puoi configurare le regole per l'accesso pubblico.
In questo modo, Cloud Storage è aperto a chiunque, anche a persone che non utilizzano la tua app, quindi assicurati di limitare di nuovo Cloud Storage quando configuri la authentication.
Creare e inizializzare firebase::App
Prima di poter accedere a Cloud Storage, devi creare e inizialize
il firebase::App.
Includi il file di intestazione per firebase::App:
#include "firebase/app.h"
Android
Crea firebase::App, passando l'ambiente JNI e un riferimento jobject all'attività Java come argomenti:
app = App::Create(AppOptions(), jni_env, activity);
iOS+
Crea firebase::App:
app = App::Create(AppOptions());
Accedere alla classe firebase::storage::Storage
La firebase::storage::Storage
classe è il punto di accesso per Cloud Storage C++ SDK.
Storage* storage = Storage::GetInstance(app);
Ora puoi iniziare a utilizzare Cloud Storage!
Passaggio successivo? Scopri come creare un Cloud Storage riferimento.
Configurazione avanzata
Esistono alcuni casi d'uso che richiedono una configurazione aggiuntiva:
- Utilizzo di Cloud Storage bucket in più regioni geografiche
- Utilizzo di Cloud Storage bucket in diverse classi di archiviazione
- Utilizzo di Cloud Storage bucket con più utenti autenticati nella stessa app
Il primo caso d'uso è perfetto se hai utenti in tutto il mondo e vuoi archiviare i loro dati nelle vicinanze. Ad esempio, puoi creare bucket negli Stati Uniti, in Europa e in Asia per archiviare i dati degli utenti in queste regioni e ridurre la latenza.
Il secondo caso d'uso è utile se hai dati con pattern di accesso diversi. Ad esempio, puoi configurare un bucket multiregionale o regionale che archivia immagini o altri contenuti a cui si accede di frequente e un bucket nearline o coldline che archivia backup utente o altri contenuti a cui si accede di rado.
In entrambi questi casi d'uso, ti consigliamo di utilizzare più Cloud Storage bucket.
Il terzo caso d'uso è utile se stai creando un'app, come Google Drive, che consente agli utenti di avere più account con accesso (ad esempio, un account personale e un account di lavoro). Puoi utilizzare un'istanza personalizzata dell'app Firebase per autenticare ogni account aggiuntivo.
Utilizzare più Cloud Storage bucket
Se vuoi utilizzare un bucket Cloud Storage diverso da quello predefinito fornito sopra,
o utilizzare più bucket Cloud Storage in una singola app, puoi creare un'istanza
di firebase::storage::Storage che fa riferimento al tuo bucket personalizzato:
// Get a non-default Cloud Storage bucket Storage* storage = Storage::GetInstance("gs://my-custom-bucket");
Utilizzare i bucket importati
Quando importi un bucket Cloud Storage esistente in Firebase, devi concedere a Firebase la possibilità di accedere a questi file utilizzando lo strumento gsutil incluso in Google Cloud SDK:
gsutil -m acl ch -r -u service-PROJECT_NUMBER@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://BUCKET_NAME
Puoi trovare il numero del progetto come descritto nell' introduzione ai progetti Firebase.
Ciò non influisce sui bucket appena creati, poiché questi hanno il controllo dell'accesso predefinito impostato per consentire Firebase. Si tratta di una misura temporanea che verrà eseguita automaticamente in futuro.
Utilizzare un'app Firebase personalizzata
Se stai creando un'app più complessa utilizzando un firebase::App personalizzato, puoi creare un'istanza di firebase::storage::Storage inizializzata con questa app:
// Get the default bucket from a custom firebase::App Storage* storage = Storage::GetInstance(customApp); // Get a non-default bucket from a custom firebase::App Storage* storage = Storage::GetInstance(customApp, "gs://my-custom-bucket");
Passaggi successivi
Preparati a lanciare l'app:
- Configura gli avvisi di budget per il tuo progetto nella console Google Cloud.
- Monitora la dashboard Utilizzo e fatturazione nella console Firebase per avere una visione generale dell'utilizzo del tuo progetto in più servizi Firebase. Puoi anche visitare la Cloud Storage dashboard Utilizzo per informazioni sull'utilizzo più dettagliate.
- Esamina la checklist di lancio di Firebase.