Облачное хранилище для Firebase позволяет загружать и делиться созданным пользователем контентом, таким как изображения и видео, что позволяет встраивать мультимедийный контент в ваши приложения. Ваши данные хранятся в корзине Google Cloud Storage — объектном хранилище эксабайтного масштаба с высокой доступностью и глобальной избыточностью. Облачное хранилище для Firebase позволяет безопасно загружать эти файлы непосредственно с мобильных устройств и веб-браузеров, с легкостью обрабатывая нестабильные сети.
Прежде чем вы начнете
Прежде чем вы сможете использовать облачное хранилище , вам необходимо:
Зарегистрируйте свой проект C++ и настройте его для использования Firebase.
Если ваш проект C++ уже использует Firebase, значит, он уже зарегистрирован и настроен для Firebase.
Добавьте Firebase C++ SDK в свой проект C++.
Обратите внимание, что добавление Firebase в ваш проект C++ включает задачи как в консоли Firebase , так и в вашем открытом проекте C++ (например, вы загружаете файлы конфигурации Firebase из консоли, а затем перемещаете их в свой проект C++).
Создание корзины Cloud Storage по умолчанию
На панели навигации консоли Firebase выберите «Хранилище» , затем нажмите «Начать» .
Ознакомьтесь с сообщениями о защите ваших данных в облачном хранилище с помощью правил безопасности. Во время разработки подумайте о настройке правил для общего доступа .
Выберите расположение для корзины Cloud Storage по умолчанию.
Этот параметр местоположения является расположением ресурса Google Cloud Platform (GCP) по умолчанию для вашего проекта . Обратите внимание, что это местоположение будет использоваться для сервисов GCP в вашем проекте, для которых требуется настройка местоположения, в частности, для вашей базы данных Cloud Firestore и вашего приложения App Engine (что требуется, если вы используете Cloud Scheduler).
Если вы не можете выбрать местоположение, значит, в вашем проекте уже есть местоположение ресурса GCP по умолчанию. Он был установлен либо при создании проекта, либо при настройке другого сервиса, требующего настройки местоположения.
Если вы пользуетесь тарифным планом Blaze, вы можете создать несколько сегментов , каждый из которых будет иметь собственное местоположение .
Щелкните Готово .
Настроить публичный доступ
Облачное хранилище для Firebase предоставляет язык декларативных правил, который позволяет вам определять, как ваши данные должны быть структурированы, как они должны индексироваться и когда ваши данные могут быть прочитаны и записаны. По умолчанию доступ к облачному хранилищу для чтения и записи ограничен, поэтому только пользователи, прошедшие проверку подлинности, могут читать или записывать данные. Чтобы начать работу без настройки аутентификации , вы можете настроить свои правила для общего доступа .
Это делает облачное хранилище открытым для всех, даже для людей, не использующих ваше приложение, поэтому не забудьте снова ограничить свое облачное хранилище при настройке аутентификации.
Создайте и инициализируйте firebase::App
Прежде чем вы сможете получить доступ к облачному хранилищу, вам необходимо создать и инициализировать firebase::App
.
Включите заголовочный файл для firebase::App
:
#include "firebase/app.h"
Андроид
Создайте firebase::App
, передав среду JNI и jobject
на проект Java Activity в качестве аргументов:
app = App::Create(AppOptions(), jni_env, activity);
iOS+
Создайте firebase::App
:
app = App::Create(AppOptions());
Доступ к классу firebase::storage::Storage
Класс firebase::storage::Storage
— это точка входа для Cloud Storage C++ SDK.
Storage* storage = Storage::GetInstance(app);
Вы готовы начать использовать облачное хранилище!
Во-первых, давайте узнаем, как создать ссылку на облачное хранилище .
Advanced Setup
Есть несколько вариантов использования, которые требуют дополнительной настройки:
- Использование сегментов Cloud Storage в нескольких географических регионах
- Использование сегментов Cloud Storage в разных классах хранилищ
- Использование сегментов Cloud Storage с несколькими пользователями, прошедшими проверку подлинности, в одном приложении
Первый вариант использования идеален, если у вас есть пользователи по всему миру и вы хотите хранить их данные рядом с ними. Например, вы можете создавать корзины в США, Европе и Азии для хранения данных для пользователей в этих регионах, чтобы уменьшить задержку.
Второй вариант использования полезен, если у вас есть данные с разными шаблонами доступа. Например: вы можете настроить многорегиональную или региональную корзину, в которой хранятся изображения или другое часто используемое содержимое, а также корзину ближней или холодной линии, в которой хранятся резервные копии пользователей или другое редко используемое содержимое.
В любом из этих вариантов использования вам понадобится несколько сегментов Cloud Storage .
Третий вариант использования полезен, если вы создаете приложение, такое как Google Диск, которое позволяет пользователям иметь несколько учетных записей (например, личную учетную запись и рабочую учетную запись). Вы можете использовать собственный экземпляр приложения Firebase для аутентификации каждой дополнительной учетной записи.
Используйте несколько сегментов облачного хранилища
Если вы хотите использовать ведро Cloud Storage, отличное от указанного выше по умолчанию, или использовать несколько сегментов Cloud Storage в одном приложении, вы можете создать экземпляр firebase::storage::Storage
, который ссылается на ваш пользовательский сегмент:
// Get a non-default Cloud Storage bucket Storage* storage = Storage::GetInstance("gs://my-custom-bucket");
Работа с импортированными сегментами
При импорте существующей корзины Cloud Storage в Firebase вам нужно будет предоставить Firebase возможность доступа к этим файлам с помощью инструмента gsutil
, включенного в Google Cloud SDK :
gsutil -m acl ch -r -u service-<project number>@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://<your-cloud-storage-bucket>
Вы можете найти номер своего проекта, как описано во введении к проектам Firebase .
Это не влияет на вновь созданные сегменты, так как для них установлен контроль доступа по умолчанию, разрешающий использование Firebase. Это временная мера, и в будущем она будет выполняться автоматически.
Используйте собственное приложение Firebase
Если вы создаете более сложное приложение с помощью пользовательского firebase::App
, вы можете создать экземпляр firebase::storage::Storage
инициализированный этим приложением:
// 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");
Следующие шаги
Подготовьтесь к запуску вашего приложения:
- Настройте оповещения о бюджете для своего проекта в Google Cloud Console.
- Отслеживайте использование и выставление счетов в консоли Firebase, чтобы получить общую картину использования вашего проекта в нескольких сервисах Firebase. Вы также можете посетить панель управления Cloud Storage Usage для получения более подробной информации об использовании.
- Ознакомьтесь с контрольным списком запуска Firebase .