Cloud Storage for Firebase umożliwia przesyłanie i udostępnianie treści generowanych przez użytkowników, takich jak obrazy i filmy, co pozwala na tworzenie w aplikacjach treści rich media. Twoje dane są przechowywane w Google Cloud Storage zasobniku – rozwiązaniu do przechowywania obiektów o skali eksabajtów, które charakteryzuje się wysoką dostępnością i globalną redundancją. Cloud Storage for Firebase umożliwia bezpieczne przesyłanie tych plików bezpośrednio z urządzeń mobilnych i przeglądarek internetowych, z łatwością radząc sobie z niestabilnymi sieciami.
Zanim zaczniesz
Zanim zaczniesz korzystać z Cloud Storage, musisz:
zarejestrować projekt C++ i skonfigurować go do korzystania z Firebase.
Jeśli Twój projekt C++ korzysta już z Firebase, jest on już zarejestrowany i skonfigurowany do korzystania z Firebase.
dodać pakiet Firebase C++ SDK do projektu C++.
Pamiętaj, że dodanie Firebase do projektu C++ wymaga wykonania zadań zarówno w Firebase konsoli Firebase, jak i w otwartym projekcie C++ (np. pobierasz pliki konfiguracyjne Firebase z konsoli, a następnie przenosisz je do projektu C++).
Upewnij się też, że Twój projekt w Firebase korzysta z abonamentu Blaze z płatnością według wykorzystania, który jest wymagany do korzystania z Cloud Storage for Firebase. Jeśli dopiero zaczynasz korzystać z Firebase i Google Cloud, sprawdź, czy kwalifikujesz się do bezpłatnego okresu próbnego o wartości 300 USD.
Tworzenie domyślnego zasobnikaCloud Storage
W konsoli Firebase otwórz Bazy danych i miejsce na dane > Miejsce na dane.
Jeśli Twój projekt nie korzysta jeszcze z abonamentu Blaze z płatnością według wykorzystania, pojawi się prośba o przejście na wyższy abonament.
Kliknij Rozpocznij.
Wybierz lokalizację domyślnego zasobnika.
Zasobniki w lokalizacjach
,US-CENTRAL1 iUS-EAST1 mogą korzystać z "Zawsze bezpłatnie" warstwy dla Google Cloud Storage. W przypadku zasobników w pozostałych lokalizacjach obowiązują Google Cloud Storage ceny i zasady użytkowania.US-WEST1Jeśli chcesz, możesz później utworzyć kilka zasobników, z których każdy będzie miał własną lokalizację.
Skonfiguruj Firebase Security Rules dla domyślnego zasobnika. Podczas programowania, rozważ skonfigurowanie reguł dostępu publicznego.
Kliknij Gotowe.
Teraz możesz wyświetlić zasobnik w konsoli Firebase (otwórz kartę
Bazy danych i miejsce na dane > Miejsce na dane >
Pliki).
Format nazwy domyślnego zasobnika to PROJECT_ID.firebasestorage.app
Konfigurowanie dostępu publicznego
Cloud Storage for Firebase udostępnia deklaratywny język reguł, który umożliwia określenie struktury danych, sposobu ich indeksowania oraz tego, kiedy można odczytywać i zapisywać dane. 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 rozpocząć bez konfigurowania Authentication, możesz skonfigurować reguły dostępu publicznego.
Spowoduje to, że Cloud Storage będzie otwarty dla wszystkich, nawet dla osób, które nie korzystają z Twojej aplikacji. Pamiętaj, aby po skonfigurowaniu uwierzytelniania ponownie ograniczyć dostęp do Cloud Storage.
Tworzenie i inicjowanie firebase::App
Zanim uzyskasz dostęp do Cloud Storage, musisz utworzyć i zainicjować
firebase::App.
Dołącz plik nagłówkowy firebase::App:
#include "firebase/app.h"
Android
Utwórz firebase::App, przekazując środowisko JNI i odwołanie jobject do działania Java jako argumenty:
app = App::Create(AppOptions(), jni_env, activity);
iOS+
Utwórz firebase::App:
app = App::Create(AppOptions());
Uzyskiwanie dostępu do zajęć firebase::storage::Storage
Klasa firebase::storage::Storage
jest punktem wejścia do pakietu Cloud Storage C++ SDK.
Storage* storage = Storage::GetInstance(app);
Możesz już zacząć korzystać z Cloud Storage!
Następny krok? Dowiedz się, jak utworzyć odwołanie.Cloud Storage
Konfiguracja zaawansowana
Istnieje kilka przypadków użycia, które wymagają dodatkowej konfiguracji:
- Korzystanie z Cloud Storage zasobników w wielu regionach geograficznych
- Korzystanie z Cloud Storage zasobników w różnych klasach pamięci
- Korzystanie z zasobników Cloud Storage z wieloma uwierzytelnionymi użytkownikami 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ć zasobniki w Stanach Zjednoczonych, Europie i Azji, aby przechowywać dane użytkowników z tych regionów i zmniejszyć opóźnienie.
Drugi przypadek użycia jest przydatny, jeśli masz dane o różnych wzorcach dostępu. Możesz na przykład skonfigurować zasobnik wieloregionowy lub regionalny, który będzie przechowywać zdjęcia lub inne często używane treści, oraz zasobnik nearline lub coldline, który będzie przechowywać kopie zapasowe użytkowników lub inne rzadko używane treści.
W obu tych przypadkach użycia warto korzystać z wielu Cloud Storage zasobników.
Trzeci przypadek użycia jest przydatny, jeśli tworzysz aplikację, taką jak Dysk Google, która umożliwia użytkownikom logowanie się na kilka kont (np. konto osobiste i konto służbowe). Do uwierzytelniania każdego dodatkowego konta możesz użyć niestandardowej instancji aplikacji Firebase.
Korzystanie z wielu zasobników Cloud Storage
Jeśli chcesz używać zasobnika Cloud Storage innego niż domyślny podany powyżej,
lub używać wielu zasobników Cloud Storage w jednej aplikacji, możesz utworzyć instancję
obiektu firebase::storage::Storage, która odwołuje się do Twojego niestandardowego zasobnika:
// Get a non-default Cloud Storage bucket Storage* storage = Storage::GetInstance("gs://my-custom-bucket");
Praca z importowanymi zasobnikami
Podczas importowania istniejącego zasobnika Cloud Storage do Firebase musisz
przyznać Firebase możliwość dostępu do tych plików za pomocą
narzędzia gsutil które jest częścią
Google Cloud SDK:
gsutil -m acl ch -r -u service-PROJECT_NUMBER@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://BUCKET_NAME
Numer projektu znajdziesz w sekcji Wprowadzenie do projektów Firebase.
Nie ma to wpływu na nowo utworzone zasobniki, ponieważ mają one domyślną kontrolę dostępu ustawioną na zezwalanie Firebase. Jest to środek tymczasowy, który w przyszłości będzie wykonywany automatycznie.
Korzystanie z niestandardowej aplikacji Firebase
Jeśli tworzysz bardziej złożoną aplikację za pomocą niestandardowej firebase::App, możesz utworzyć instancję firebase::storage::Storage zainicjowaną za pomocą tej aplikacji:
// 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");
Dalsze kroki
Przygotuj się na uruchomienie aplikacji:
- Skonfiguruj budżet alertów dla projektu w Google Cloud konsoli.
- Monitoruj panel Użycie i płatności w konsoli Firebase aby uzyskać ogólny obraz wykorzystania projektu w różnych usługach Firebase. Aby uzyskać bardziej szczegółowe informacje o użyciu, możesz też otworzyć panel Cloud Storage Użycie dashboard w Cloud Storage.
- Zapoznaj się z listą kontrolną uruchomienia Firebase.