C++ için Cloud Storage ile dosya meta verilerini kullanma

Cloud Storage referansına dosya yükledikten sonra şunu da alabilirsiniz: ve dosya meta verilerini güncelleyin (örneğin, içerik türünü güncellemek için). Dosyalar özel anahtar/değer çiftlerini ek dosya meta verileriyle birlikte de depolayabilir.

Dosya Meta Verilerini Alma

Dosya meta verileri name, size ve content_type (genellikle MIME türü olarak adlandırılır) ve daha seyrek görülen bazı yöntemler content_disposition ve time_created gibi olanlar. Bu meta veri, GetMetadata kullanılarak bir Cloud Storage referansından alındı yöntemidir.

// Create reference to the file whose metadata we want to retrieve
StorageReference forest_ref = storage_ref.Child("images/forest.jpg");

// Get metadata properties
Future future = forest_ref.GetMetadata();

// Wait for Future to complete...

if (future.Error() != firebase::storage::kErrorNone) {
  // Uh-oh, an error occurred!
} else {
  // We can now retrieve the metadata for 'images/forest.jpg'
  Metadata* metadata = future.Result();
}

Dosya Meta Verilerini Güncelleme

Dosya meta verilerini, dosya yüklemesi tamamlandıktan sonra istediğiniz zaman (UpdateMetadata yöntemini kullanarak). Daha fazla bilgi için özellikleri hakkında daha fazla bilgi için tam listeye güncellenebilir. Yalnızca meta veride belirtilen özellikler güncellenir, diğer tüm değişiklikler değiştirilmeden bırakılır.

// Create reference to the file whose metadata we want to change
firebase::storage::StorageReference forest_ref = storage_ref.child("images/forest.jpg");

// Create file metadata to update
Metadata new_metadata;
newMetadata.set_cache_control("public,max-age=300");
newMetadata.set_content_type("image/jpeg");

// Update metadata properties
Future future = forest_ref.UpdateMetadata(new_metadata);

// Wait for Future to complete...

if (future.Error() != firebase::storage::kErrorNone) {
  // Uh-oh, an error occurred!
} else {
  // We can now retrieve the updated metadata for 'images/forest.jpg'
  Metadata* metadata = future.Result();
}

Boş dizeyi ileterek yazılabilir meta veri özelliklerini silebilirsiniz:

// Create file metadata with property to delete
StorageMetadata new_metadata;
new_metadata.set_content_type("");

// Delete the metadata property
Future future = forest_ref.UpdateMetadata(new_metadata);

// Wait for Future to complete...

if (future.Error() != 0) {
  // Uh-oh, an error occurred!
} else {
  // metadata.content_type() should be an empty string
  Metadata* metadata = future.Result();
}

Hataları Giderme

Bilgileri alma veya güncelleme sırasında hataların oluşmasının birkaç nedeni vardır: mevcut olmayan veya kullanıcının izni olmayan kullanıcı da dahil olmak üzere meta veriler istediğiniz dosyaya erişin. Hatalarla ilgili daha fazla bilgiyi şurada bulabilirsiniz: Hataları İşleme bölümünde bulabilirsiniz.

Özel Meta Veriler

Özel meta verileri, std::string içeren bir std::map olarak belirtebilirsiniz. özellikler.

std::map* custom_metadata = metadata.custom_metadata();
custom_metadata->insert(std::make_pair("location", "Yosemite, CA, USA");
custom_metadata->insert(std::make_pair("activity", "Hiking");

Her dosya için uygulamaya özel verileri özel meta verilerde saklayabilirsiniz. Ancak bir veritabanı (örneğin, Firebase Realtime Database) kullanın ve bu veri türünü senkronize edin dışı verilerdir.

Dosya Meta Verisi Özellikleri

Bir dosyadaki meta veri özelliklerinin tam listesini aşağıda bulabilirsiniz:

Özellik Tür Yazılabilir
bucket sabit karakter* HAYIR
generation sabit karakter* HAYIR
metageneration sabit karakter* HAYIR
full_path sabit karakter* HAYIR
name sabit karakter* HAYIR
size int64_t HAYIR
time_created int64_t HAYIR
updated int64_t HAYIR
cache_control sabit karakter* EVET
content_disposition sabit karakter* EVET
content_encoding sabit karakter* EVET
content_language sabit karakter* EVET
content_type sabit karakter* EVET
download_urls std::vector<std::string> HAYIR
custom_metadata std::map<std::string, std::string> EVET

Sonraki adımlar

Dosya yüklemek, indirmek ve güncellemek önemlidir ancak tıklayın. Şimdi nasıl uygulayacağımızı dosyaları sil Cloud Storage'dan edinilebilir.