Cloud Storage dla Firebase umożliwia przesyłanie i udostępnianie treści generowanych przez użytkowników, takich jak obrazy i filmy, co pozwala tworzyć w aplikacjach multimedia. Twoje dane są przechowywane w zasobniku Google Cloud Storage – rozwiązaniu do obiektowej pamięci masowej o zasobach exabajtów z wysoką dostępnością i globalną redundancją. Cloud Storage dla Firebase umożliwia bezpieczne przesyłanie tych plików bezpośrednio z urządzeń mobilnych i przeglądarek internetowych, a także łatwe radzenie sobie z problemami z siecią.
Zanim zaczniesz
Jeśli jeszcze tego nie zrobisz, zapoznaj się z przewodnikiem po aplikacjach Flutter. Obejmuje to m.in.:
Tworzenie projektu Firebase.
Instalowanie i inicjowanie pakietów SDK Firebase dla Fluttera.
Upewnij się, że Twój projekt Firebase jest objęty abonamentem Blaze (płatność według zużycia zasobów). Jeśli dopiero zaczynasz korzystać z Firebase i Google Cloud, sprawdź, czy kwalifikujesz się do otrzymania 300 USD w postaci środków.
Tworzenie domyślnego zasobnika Cloud Storage
W panelu nawigacyjnym konsoli Firebase wybierz Przechowywanie danych.
Jeśli Twój projekt nie jest jeszcze objęty cennikiem Blaze, pojawi się prośba o zaktualizowanie projektu.
Kliknij Rozpocznij.
Wybierz lokalizację domyślnego zasobnika.
Grupy w poziomie
,US-CENTRAL1
iUS-EAST1
mogą korzystać z poziomu „Zawsze bezpłatnie” w usłudze Google Cloud Storage. Segmenty w pozostałych lokalizacjach mają ceny i użycie zgodne z Google Cloud Storage.US-WEST1
Jeśli chcesz, możesz później utworzyć kilka puli, z których każda będzie mieć swoją lokalizację.
Skonfiguruj Firebase Security Rules dla domyślnego zasobnika. Podczas tworzenia aplikacji rozważ ustawienie reguł dotyczących dostępu publicznego.
Kliknij Gotowe.
Zasobnik możesz teraz wyświetlić na karcie Cloud Storage Pliki konsoli Firebase. Domyślny format nazwy zasobnika to PROJECT_ID.firebasestorage.app
Konfigurowanie dostępu publicznego
Cloud Storage dla Firebase udostępnia język deklaratywny, który umożliwia określenie struktury danych, sposobu ich indeksowania oraz czasu, w którym można je odczytywać i zapisywać. Domyślnie dostęp do odczytu i zapisu w Cloud Storage jest ograniczony, więc tylko uwierzytelnieni użytkownicy mogą odczytywać i zapisywać dane. Aby zacząć korzystać z tej funkcji bez konfigurowania Uwierzytelniania Firebase, możesz skonfigurować reguły dostępu publicznego.
Spowoduje to, że Cloud Storage będzie dostępny dla wszystkich, nawet osób, które nie korzystają z Twojej aplikacji. Pamiętaj, aby ponownie ograniczyć dostęp do Cloud Storage po skonfigurowaniu uwierzytelniania.
Dodawanie do aplikacji pakietu SDK Cloud Storage
Aby zainstalować w katalogu głównym projektu Flutter wtyczkę, uruchom to polecenie:
flutter pub add firebase_storage
Po zakończeniu ponownie skompiluj aplikację Flutter:
flutter run
Zaimportuj wtyczkę w kodzie Darta:
import 'package:firebase_storage/firebase_storage.dart';
Konfigurowanie Cloud Storage
Uruchom
flutterfire configure
w katalogu projektu Flutter. W ten sposób aktualizujesz plik konfiguracji Firebase (firebase_options.dart
) w kodzie źródłowym aplikacji, aby miał nazwę domyślnego zasobnika Cloud Storage.Uzyskaj dostęp do zasobnika Cloud Storage, tworząc instancję:
FirebaseStorage
:final storage = FirebaseStorage.instance; // Alternatively, explicitly specify the bucket name URL. // final storage = FirebaseStorage.instanceFor(bucket: "gs://<var>BUCKET_NAME</var>");
Możesz już zacząć korzystać z Cloud Storage.
Co dalej? Dowiedz się, jak utworzyć odwołanie do Cloud Storage.
Konfiguracja zaawansowana
Niektóre przypadki użycia wymagają dodatkowej konfiguracji:
- Korzystanie z zasobników Cloud Storage w wielu regionach geograficznych
- Korzystanie z zasobników Cloud Storage w różnych klasach
- Korzystanie z zasobników Cloud Storage przez wielu uwierzytelnionych użytkowników w tej samej aplikacji
Pierwszy przypadek użycia jest idealny, jeśli masz użytkowników na całym świecie i chcesz przechowywać ich dane w pobliżu. Możesz na przykład utworzyć zbiory w Stanach Zjednoczonych, Europie i Azji, aby przechowywać dane użytkowników z tych regionów i w ten sposób zmniejszyć opóźnienia.
Drugi przypadek użycia jest przydatny, jeśli masz dane z różnymi wzorcami dostępu. Możesz na przykład skonfigurować zasobnik wieloregionalny lub regionalny, w którym będą przechowywane zdjęcia lub inne często używane treści, oraz zasobnik nearline lub coldline, w którym będą przechowywane kopie zapasowe użytkowników lub inne rzadko używane treści.
W każdym z tych przypadków warto użyć wielu zasobników Cloud Storage.
Trzeci przypadek użycia jest przydatny, jeśli tworzysz aplikację, taką jak Dysk Google, która umożliwia użytkownikom logowanie się na wiele kont (np. na konto osobiste i służbowe). Możesz użyć niestandardowej aplikacji Firebase, aby uwierzytelniać każde dodatkowe konto.
Korzystanie z wielu zasobników Cloud Storage
Jeśli chcesz użyć zasobnika Cloud Storage innego niż domyślny podany powyżej lub użyć kilku zasobników Cloud Storage w jednej aplikacji, możesz utworzyć instancję FirebaseStorage
, która odwołuje się do niestandardowego zasobnika:
// Get a non-default Storage bucket
final storage = FirebaseStorage.instanceFor(bucket: "gs://my-custom-bucket");
Praca z zaimportowanymi zasobnikami
Podczas importowania istniejącego zasobnika Cloud Storage do Firebase musisz przyznać Firebase uprawnienia dostępu do tych plików za pomocą narzędzia gsutil
, które jest częścią pakietu Google Cloud SDK:
gsutil -m acl ch -r -u service-PROJECT_NUMBER@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://YOUR-CLOUD-STORAGE-BUCKET
Numer projektu znajdziesz w sposób opisany w wprowadzeniu do projektów Firebase.
Nie ma to wpływu na nowo utworzone zasobniki, ponieważ mają one domyślnie ustawioną kontrolę dostępu, która zezwala na dostęp do Firebase. Jest to środek tymczasowy, który w przyszłości będzie wykonywany automatycznie.
Używanie niestandardowej aplikacji Firebase
Jeśli tworzysz bardziej skomplikowaną aplikację za pomocą niestandardowego obiektu FirebaseApp
, możesz utworzyć instancję obiektu FirebaseStorage
zainicjalizowanego za pomocą tej aplikacji:
// Use a non-default App
final storage = FirebaseStorage.instanceFor(app: customApp);
Dalsze kroki
- Przygotuj się do uruchomienia aplikacji:
- Włącz Sprawdzanie aplikacji, aby mieć pewność, że tylko Twoje aplikacje będą miały dostęp do zasobników na dane.
- Skonfiguruj alerty dotyczące budżetu dla projektu w konsoli Google Cloud.
- W konsoli Firebase możesz sprawdzać panel Korzystanie i rozliczenia, aby uzyskać ogólny obraz wykorzystania projektu w różnych usługach Firebase. Więcej szczegółowych informacji o wykorzystaniu znajdziesz też w panelu Wykorzystanie Cloud Storage.
- Przejrzyj listę kontrolną przed wdrożeniem Firebase.