ইউনিটির জন্য ক্লাউড স্টোরেজ সহ ফাইল মেটাডেটা ব্যবহার করুন

Cloud Storage রেফারেন্সে একটি ফাইল আপলোড করার পরে, আপনি ফাইল মেটাডেটা পেতে এবং আপডেট করতে পারেন, উদাহরণস্বরূপ কন্টেন্ট টাইপ আপডেট করতে। ফাইলগুলি অতিরিক্ত ফাইল মেটাডেটা সহ কাস্টম কী/মান জোড়াও সংরক্ষণ করতে পারে।

ফাইল মেটাডেটা পান

ফাইল মেটাডেটাতে Name , SizeBytes এবং ContentType (প্রায়শই MIME টাইপ হিসাবে উল্লেখ করা হয়) এর মতো সাধারণ বৈশিষ্ট্য রয়েছে, এছাড়াও ContentDisposition এবং CreationTimeMillis মতো কিছু কম সাধারণ বৈশিষ্ট্য রয়েছে। GetMetadataAsync পদ্ধতি ব্যবহার করে Cloud Storage রেফারেন্স থেকে এই মেটাডেটা পুনরুদ্ধার করা যেতে পারে।

// 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 ) ব্যবহার করার পরামর্শ দিচ্ছি।

ফাইল মেটাডেটা বৈশিষ্ট্য

একটি ফাইলের মেটাডেটা বৈশিষ্ট্যের সম্পূর্ণ তালিকা নীচে পাওয়া যাবে:

সম্পত্তি আদর্শ মেটাডেটা পরিবর্তনে পরিবর্তনযোগ্য
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 থেকে ফাইলগুলি কীভাবে মুছবেন