Cloud Storage for Firebase ermöglicht das Hochladen und Teilen von nutzergenerierten Inhalten wie Bildern und Videos, sodass Sie Ihre Apps mit Rich-Media-Inhalten anreichern können. Ihre Daten werden in einem Google Cloud Storage Bucket gespeichert. Das ist eine Objektspeicherlösung im Exabyte-Bereich mit Hochverfügbarkeit und globaler Redundanz. Cloud Storage for Firebase ermöglicht Ihnen das sichere Hochladen dieser Dateien direkt von Mobilgeräten und Webbrowsern, auch bei instabilen Netzwerken mit Leichtigkeit.
Hinweis
Wenn Sie es noch nicht getan haben, folgen Sie der Anleitung Erste Schritte für Apps auf Apple-Plattformen. Dazu zählen:
Ein Firebase-Projekt erstellen
Ihre App auf Apple-Plattformen im Projekt registrieren und Ihre App mit Firebase verbinden, indem Sie die Firebase-Bibliothek und Ihre Firebase-Konfigurationsdatei (
GoogleService-Info.plist) zu Ihrer App hinzufügen
Achten Sie darauf, dass für Ihr Firebase-Projekt der Blaze-Preismodell (Pay as you go) gilt. Das ist eine Voraussetzung für die Verwendung von Cloud Storage for Firebase. Wenn Sie Firebase und Google Cloud noch nicht kennen, prüfen Sie, ob Sie Anspruch auf ein Startguthaben von 300 $ für die kostenlose Testversion haben.
Standard-Cloud Storage Bucket erstellen
Rufen Sie in der Firebase Konsole Databases & Storage > Storage auf.
Wenn für Ihr Projekt noch nicht der Blaze-Tarif (Pay as you go) gilt, werden Sie aufgefordert, ein Upgrade für Ihr Projekt durchzuführen.
Klicken Sie auf Jetzt starten.
Wählen Sie einen Standort für Ihren Standard-Bucket aus.
Für Buckets in
,US-CENTRAL1 undUS-EAST1 kann der Tarif „Immer kostenlos“ für Google Cloud Storage genutzt werden. Für Buckets an allen anderen Standorten gelten Google Cloud Storage Preise und Nutzungsbedingungen.US-WEST1Sie können später mehrere Buckets mit jeweils eigenem Standort erstellen.
Konfigurieren Sie die Firebase Security Rules für Ihren Standard-Bucket. Während der Entwicklung sollten Sie Regeln für den öffentlichen Zugriff einrichten.
Klicken Sie auf Fertig.
Sie können den Bucket jetzt in der Firebase Konsole ansehen. Rufen Sie dazu den
Databases & Storage > Storage >
Files Tab auf.
Das Standardformat für den Namen Ihres Buckets ist PROJECT_ID.firebasestorage.app
Öffentlichen Zugriff einrichten
Cloud Storage for Firebase bietet eine deklarative Regelsprache, mit der Sie definieren können, wie Ihre Daten strukturiert und indexiert werden sollen und wann Ihre Daten gelesen und geschrieben werden können. Standardmäßig ist der Lese- und Schreibzugriff auf Cloud Storage eingeschränkt, sodass nur authentifizierte Nutzer Daten lesen oder schreiben können. Wenn Sie ohne Einrichtung von Authentication beginnen möchten, können Sie Ihre Regeln für den öffentlichen Zugriff konfigurieren.
Dadurch wird Cloud Storage für alle geöffnet, auch für Personen, die Ihre App nicht verwenden. Sie sollten Cloud Storage daher wieder einschränken, wenn Sie die Authentifizierung einrichten.
Cloud Storage zu Ihrer App hinzufügen
Verwenden Sie Swift Package Manager, um Firebase-Abhängigkeiten zu installieren und zu verwalten.
- Öffnen Sie Ihr App-Projekt und gehen Sie in Xcode zu File > Add Packages (Datei > Pakete hinzufügen).
- Fügen Sie bei entsprechender Aufforderung das Firebase Apple Platforms SDK-Repository hinzu:
- Wählen Sie die Cloud Storage Bibliothek aus.
- Fügen Sie das Flag
-ObjCim Bereich Other Linker Flags (Weitere Verknüpfungsmerker) der Buildeinstellungen Ihres Ziels hinzu. - Wenn Sie fertig, beginnt Xcode automatisch, Ihre Abhängigkeiten im Hintergrund aufzulösen und herunterzuladen.
https://github.com/firebase/firebase-ios-sdk.git
Cloud Storage in Ihrer App einrichten
Initialisieren Sie Firebase, bevor ein Firebase-Verweis erstellt oder verwendet wird.
Möglicherweise haben Sie das bereits getan, wenn Sie ein anderes Firebase-Produkt eingerichtet haben. Sie müssen jedoch die Bibliothek
FirebaseStoragezu Ihrer Liste der Importe hinzufügen.Importieren Sie das Modul
FirebaseCoreund das ModulFirebaseStorageinUIApplicationDelegate. Wir empfehlen außerdem,FirebaseAuthhinzuzufügen.SwiftUI
import SwiftUI import FirebaseCore import FirebaseStorage import FirebaseAuth // ...Swift
import FirebaseCore import FirebaseStorage import FirebaseAuth // ...Objective-C
@import FirebaseCore; @import FirebaseStorage; @import FirebaseAuth; // ...Konfigurieren Sie eine
FirebaseAppfreigegebene Instanz in derapplication(_:didFinishLaunchingWithOptions:)Methode Ihres App-Delegaten:SwiftUI
// Use Firebase library to configure APIs FirebaseApp.configure()Swift
// Use Firebase library to configure APIs FirebaseApp.configure()Objective-C
// Use Firebase library to configure APIs [FIRApp configure];(Nur SwiftUI) Erstellen Sie einen App-Delegaten und fügen Sie ihn mit
UIApplicationDelegateAdaptoroderNSApplicationDelegateAdaptoran IhreAppStruktur an. Sie müssen außerdem das Swizzling des App-Delegaten deaktivieren. Weitere Informationen finden Sie in der SwiftUI-Anleitung.SwiftUI
@main struct YourApp: App { // Register app delegate for Firebase setup @UIApplicationDelegateAdaptor(AppDelegate.self) var delegate var body: some Scene { WindowGroup { NavigationView { ContentView() } } } }
Rufen Sie mit der Standard-Firebase-App einen Verweis auf den Cloud Storage Dienst ab.
Achten Sie darauf, dass die Firebase-Konfigurationsdatei (
GoogleService-Info.plist) in der Codebasis Ihrer App mit dem Namen Ihres Standard-Cloud Storage Buckets aktualisiert wird.Ersetzen Sie mit dieser heruntergeladenen Konfigurationsdatei die vorhandene Datei replace
GoogleService-Info.plistim Stammverzeichnis Ihres Xcode-Projekts. Wählen Sie bei Aufforderung aus, die Konfigurationsdatei allen Zielen hinzuzufügen.Achten Sie darauf, dass in Ihrer App nur diese neueste heruntergeladene Konfigurationsdatei vorhanden ist und dass dem Dateinamen keine zusätzlichen Zeichen wie
(2)angehängt wurden.
Rufen Sie mit der Standard- Firebase-App einen Verweis auf den Cloud Storage Dienst ab:
Swift
let storage = Storage.storage()
// Alternatively, explicitly specify the bucket name URL. storage = Storage.storage(url:"gs://BUCKET_NAME")
Objective-C
FIRStorage *storage = [FIRStorage storage];
// Alternatively, explicitly specify the bucket name URL. // FIRStorage storage = [FIRStorage storageWithURL:@"gs://BUCKET_NAME"];
Sie können Cloud Storage jetzt verwenden.
Was ist der nächste Schritt? Informationen zum Erstellen eines VerweisesCloud Storage.
Erweiterte Einrichtung
Für einige Anwendungsfälle ist eine zusätzliche Einrichtung erforderlich:
- Cloud Storage Buckets in mehreren geografischen Regionen verwenden
- Cloud Storage Buckets in verschiedenen Speicherklassen verwenden
- Cloud Storage Buckets mit mehreren authentifizierten Nutzern in derselben App verwenden
Der erste Anwendungsfall ist ideal, wenn Sie Nutzer auf der ganzen Welt haben und ihre Daten in ihrer Nähe speichern möchten. Sie können beispielsweise Buckets in den USA, Europa und Asien erstellen, um Daten für Nutzer in diesen Regionen zu speichern und so die Latenz zu verringern.
Der zweite Anwendungsfall ist hilfreich, wenn Sie Daten mit unterschiedlichen Zugriffsmustern haben. Sie können beispielsweise einen multiregionalen oder regionalen Bucket einrichten, in dem Bilder oder andere häufig aufgerufene Inhalte gespeichert werden, und einen Nearline- oder Coldline-Bucket, in dem Nutzersicherungen oder andere selten aufgerufene Inhalte gespeichert werden.
In beiden Anwendungsfällen sollten Sie mehrere Cloud Storage Buckets verwenden.
Der dritte Anwendungsfall ist nützlich, wenn Sie eine App wie Google Drive entwickeln, mit der Nutzer mehrere angemeldete Konten haben können (z. B. ein privates und ein Arbeitskonto). Sie können eine benutzerdefinierte Firebase-App-Instanz verwenden, um jedes zusätzliche Konto zu authentifizieren.
Mehrere Cloud Storage Buckets verwenden
Wenn Sie einen Cloud Storage Bucket anstelle des oben genannten Standard-Buckets verwenden oder mehrere Cloud Storage Buckets in einer einzelnen App verwenden möchten, können Sie eine Instanz von FIRStorage erstellen, die auf Ihren benutzerdefinierten Bucket verweist:
Swift
// Get a non-default Cloud Storage bucket storage = Storage.storage(url:"gs://my-custom-bucket")
Objective-C
// Get a non-default Cloud Storage bucket FIRStorage storage = [FIRStorage storageWithURL:@"gs://my-custom-bucket"];
Mit importierten Buckets arbeiten
Wenn Sie einen vorhandenen Cloud Storage Bucket in Firebase importieren, müssen Sie Firebase die Berechtigung erteilen, auf diese Dateien zuzugreifen. Verwenden Sie dazu das
gsutil Tool, das im
Google Cloud SDK enthalten ist:
gsutil -m acl ch -r -u service-PROJECT_NUMBER@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://BUCKET_NAME
Ihre Projektnummer finden Sie wie in der Einführung zu Firebase-Projekten beschrieben.
Dies hat keine Auswirkungen auf neu erstellte Buckets, da für diese standardmäßig die Zugriffssteuerung so festgelegt ist, dass Firebase Zugriff hat. Dies ist eine vorübergehende Maßnahme, die in Zukunft automatisch ausgeführt wird.
Benutzerdefinierte Firebase-App verwenden
Wenn Sie eine komplexere App mit einer benutzerdefinierten FirebaseApp erstellen, können Sie eine Instanz von Storage erstellen, die mit dieser App initialisiert wird:
Swift
// Get the default bucket from a custom FirebaseApp storage = Storage.storage(app:customApp) // Get a non-default bucket from a custom FirebaseApp storage = Storage.storage(app:customApp, url:"gs://my-custom-bucket")
Objective-C
// Get the default bucket from a custom FIRApp FIRStorage storage = [FIRStorage storageForApp:customApp]; // Get a non-default bucket from a custom FIRApp FIRStorage storage = [FIRStorage storageForApp:customApp withURL:@"gs://my-custom-bucket"];
Nächste Schritte
App-Start vorbereiten:
Aktivieren Sie App Check, um sicherzustellen, dass nur Ihre Apps auf Ihre Speicher-Buckets zugreifen können.
Richten Sie Budget benachrichtigungen für Ihr Projekt in der Google Cloud Console ein.
Auf dem Nutzung und Abrechnung Dashboard in der Firebase Konsole erhalten Sie einen Überblick über die Nutzung Ihres Projekts in mehreren Firebase-Diensten. Weitere Informationen zur Nutzung finden Sie auf dem Cloud Storage Nutzung Dashboard von Cloud Storage.
Prüfen Sie die Checkliste für den Firebase-Start.