Создайте ссылку на облачное хранилище с помощью Cloud Storage for Unity.

Ваши файлы хранятся в контейнере Cloud Storage . Файлы в этом контейнере представлены в иерархической структуре, подобно файловой системе на локальном жестком диске или данным в Firebase Realtime Database . Создавая ссылку на файл, ваше приложение получает к нему доступ. Эти ссылки затем можно использовать для загрузки или скачивания данных, получения или обновления метаданных, а также для удаления файла. Ссылка может указывать как на конкретный файл, так и на узел более высокого уровня в иерархии.

Если вы использовали Firebase Realtime Database , эти пути должны показаться вам очень знакомыми. Однако ваши данные хранятся в Cloud Storage , а не в Realtime Database .

Создать ссылку

Создайте ссылку для загрузки, скачивания или удаления файла, а также для получения или обновления его метаданных. Ссылку можно рассматривать как указатель на файл в облаке. Ссылки занимают мало места, поэтому вы можете создавать их столько, сколько вам нужно. Их также можно использовать повторно для различных операций.

Ссылки создаются из сервиса Firebase.Storage.FirebaseStorage в вашем приложении Firebase путем вызова метода GetReferenceFromUrl() и передачи URL-адреса вида gs://<your-cloud-storage-bucket> . Этот URL-адрес можно найти в разделе «Хранилище» консоли Firebase .

// Get a reference to the storage service, using the default Firebase App
FirebaseStorage storage = FirebaseStorage.DefaultInstance;

// Create a storage reference from our storage service
StorageReference storageRef =
    storage.GetReferenceFromUrl("gs://<your-cloud-storage-bucket>");

Вы можете создать ссылку на местоположение ниже в дереве, например, 'images/space.jpg' , используя метод child для существующей ссылки.

// Create a child reference
// imagesRef now points to "images"
StorageReference imagesRef = storageRef.Child("images");

// Child references can also take paths delimited by '/' such as:
// "images/space.jpg".
StorageReference spaceRef = imagesRef.Child("space.jpg");
// spaceRef now points to "images/space.jpg"
// imagesRef still points to "images"

// This is equivalent to creating the full referenced
StorageReference spaceRefFull = storage.GetReferenceFromUrl(
    "gs://<your-cloud-storage-bucket>/images/space.jpg");

Вы также можете использовать методы Parent и Root для навигации по файловой иерархии. Parent перемещает на один уровень вверх, а Root — на самый верх.

// Parent allows us to move to the parent of a reference
// imagesRef now points to 'images'
StorageReference imagesRef = spaceRef.Parent;

// Root allows us to move all the way back to the top of our bucket
// rootRef now points to the root
StorageReference rootRef = spaceRef.Root;

Child , Parent и Root могут быть объединены в цепочку несколько раз, поскольку каждый из них возвращает ссылку. Исключением является Parent для Root , который является недопустимым StorageReference .

// References can be chained together multiple times
// earthRef points to "images/earth.jpg"
StorageReference earthRef =
    spaceRef.Parent.Child("earth.jpg");

// nullRef is null since the parent of root is an invalid StorageReference
StorageReference nullRef = spaceRef.Root.Parent;

Референтные методы

Вы можете просматривать ссылки, чтобы лучше понять, на какие файлы они указывают, используя свойства Path , Name и Bucket . Эти свойства содержат полный путь к файлу, его имя и контейнер.

// Reference's path is: "images/space.jpg"
// This is analogous to a file path on disk
string path = spaceRef.Path;

// Reference's name is the last segment of the full path: "space.jpg"
// This is analogous to the file name
string name = spaceRef.Name;

// Reference's bucket is the name of the storage bucket where files are stored
string bucket = spaceRef.Bucket;

Ограничения на ссылки

Пути ссылок и имена могут содержать любую последовательность допустимых символов Unicode, но налагаются определенные ограничения, в том числе:

  1. Общая длина reference.Path должен быть от 1 до 1024 байт в кодировке UTF-8.
  2. Символы возврата каретки и перевода строки отсутствуют.
  3. Избегайте использования # , [ , ] , * или ? , поскольку они плохо работают с другими инструментами, такими как Firebase Realtime Database или gsutil .

Полный пример

FirebaseStorage storage = FirebaseStorage.DefaultInstance;

// Points to the root reference
StorageReference storageRef =
    storage.GetReferenceFromUrl("gs://<your-bucket-name>");

// Points to "images"
StorageReference imagesRef = storageRef.Child("images");

// Points to "images/space.jpg"
// Note that you can use variables to create child values
string filename = "space.jpg";
StorageReference spaceRef = imagesRef.Child(filename);

// File path is "images/space.jpg"
string path = spaceRef.Path;

// File name is "space.jpg"
string name = spaceRef.Name;

// Points to "images"
StorageReference imagesRef = spaceRef.Parent;

Следующие шаги

Далее давайте узнаем, как загружать файлы в Cloud Storage .