После загрузки файла в Cloud Storage вы также можете получить и обновить метаданные файла, например, для обновления типа контента. Файлы также могут хранить пользовательские пары «ключ/значение» с дополнительными метаданными.
Получить метаданные файла
Метаданные файла содержат общие свойства, такие как Name
, SizeBytes
и ContentType
(часто называемый типом MIME), а также некоторые менее распространённые, такие как ContentDisposition
и CreationTimeMillis
. Эти метаданные можно получить из ссылки на Cloud Storage с помощью метода GetMetadataAsync
.
// Create reference to the file whose metadata we want to retrieve StorageReference forestRef = storageRef.Child("images/forest.jpg"); // Get metadata properties forestRef.GetMetadataAsync().ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { StorageMetadata meta = task.Result; // do stuff with meta } });
Обновить метаданные файла
Вы можете обновить метаданные файла в любой момент после его загрузки с помощью метода UpdateMetadataAsync
, принимающего объект MetadataChange
. Подробнее о том, какие свойства можно обновить, см. в полном списке . Обновляются только свойства, указанные в метаданных, все остальные остаются без изменений.
// Create reference to the file whose metadata we want to change StorageReference forestRef = storageRef.Child("images/forest.jpg"); // Create file metadata to update var newMetadata = new MetadataChange(); newMetadata.CacheControl = "public,max-age=300"; newMetadata.ContentType = "image/jpeg"; // Update metadata properties forestRef.UpdateMetadataAsync(newMetadata).ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { // access the updated meta data StorageMetadata meta = task.Result; } });
Вы можете удалить записываемые свойства метаданных, передав пустую строку:
// Create file metadata to update var newMetadata = new MetadataChange(); newMetadata.ContentType = ""; // Update metadata properties forestRef.UpdateMetadataAsync(newMetadata).ContinueWithOnMainThread(task => { if (!task.IsFaulted && !task.IsCanceled) { StorageMetadata meta = task.Result; // meta.ContentType should be an empty string now } });
Обработка ошибок
Ошибки при получении или обновлении метаданных могут возникать по ряду причин, включая отсутствие файла или отсутствие у пользователя прав доступа к нужному файлу. Подробнее об ошибках можно узнать в разделе «Обработка ошибок» документации.
Пользовательские метаданные
Вы можете указать пользовательские метаданные как Dictionary<string, string>
.
var newMetadata = new MetadataChange { CustomMetadata = new Dictionary<string, string> { {"location", "Yosemite, CA, USA"}, {"activity", "Hiking"} } }; // UpdateMetadataAsync
Вы можете хранить специфичные для приложения данные для каждого файла в пользовательских метаданных, но мы настоятельно рекомендуем использовать базу данных (например, Firebase Realtime Database ) для хранения и синхронизации этого типа данных.
Свойства метаданных файла
Полный список свойств метаданных файла доступен ниже:
Свойство | Тип | Изменяемо в MetadataChange |
---|---|---|
Bucket | string | НЕТ |
Generation | string | НЕТ |
MetadataGeneration | string | НЕТ |
Path | string | НЕТ |
Name | string | НЕТ |
SizeBytes | long | НЕТ |
CreationTimeMillis | long | НЕТ |
UpdatedTimeMillis | long | НЕТ |
CacheControl | string | ДА |
ContentDisposition | string | ДА |
ContentEncoding | string | ДА |
ContentLanguage | string | ДА |
ContentType | string | ДА |
DownloadUrl | Uri | НЕТ |
DownloadUrls | IList<Uri> | НЕТ |
CustomMetadataKeys | IEnumerable<string> | ДА |
Следующие шаги
Загрузка, скачивание и обновление файлов важны, но не менее важна и возможность их удаления. Давайте узнаем, как удалить файлы из Cloud Storage .