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

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

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

ফাইল মেটাডেটাতে name , size , এবং contentType (প্রায়শই MIME টাইপ হিসাবে উল্লেখ করা হয়) এর মতো সাধারণ বৈশিষ্ট্য রয়েছে, contentDisposition এবং timeCreated মতো কিছু কম সাধারণ বৈশিষ্ট্য ছাড়াও। এই মেটাডেটা getMetadata() পদ্ধতি ব্যবহার করে Cloud Storage রেফারেন্স থেকে পুনরুদ্ধার করা যেতে পারে। getMetadata() সম্পূর্ণ মেটাডেটা ধারণকারী একটি Promise প্রদান করে, অথবা Promise প্রত্যাখ্যান করলে একটি ত্রুটি প্রদান করে।

Web

import { getStorage, ref, getMetadata } from "firebase/storage";

// Create a reference to the file whose metadata we want to retrieve
const storage = getStorage();
const forestRef = ref(storage, 'images/forest.jpg');

// Get metadata properties
getMetadata(forestRef)
  .then((metadata) => {
    // Metadata now contains the metadata for 'images/forest.jpg'
  })
  .catch((error) => {
    // Uh-oh, an error occurred!
  });

Web

// Create a reference to the file whose metadata we want to retrieve
var forestRef = storageRef.child('images/forest.jpg');

// Get metadata properties
forestRef.getMetadata()
  .then((metadata) => {
    // Metadata now contains the metadata for 'images/forest.jpg'
  })
  .catch((error) => {
    // Uh-oh, an error occurred!
  });

ফাইল মেটাডেটা আপডেট করুন

ফাইল আপলোড সম্পন্ন হওয়ার পর আপনি যেকোনো সময় updateMetadata() পদ্ধতি ব্যবহার করে ফাইল মেটাডেটা আপডেট করতে পারেন। কোন বৈশিষ্ট্যগুলি আপডেট করা যেতে পারে সে সম্পর্কে আরও তথ্যের জন্য সম্পূর্ণ তালিকাটি দেখুন। শুধুমাত্র মেটাডেটাতে উল্লেখিত বৈশিষ্ট্যগুলি আপডেট করা হয়, বাকিগুলি অপরিবর্তিত থাকে। updateMetadata() সম্পূর্ণ মেটাডেটা ধারণকারী একটি Promise প্রদান করে, অথবা Promise প্রত্যাখ্যান করলে একটি ত্রুটি প্রদান করে।

Web

import { getStorage, ref, updateMetadata } from "firebase/storage";

// Create a reference to the file whose metadata we want to change
const storage = getStorage();
const forestRef = ref(storage, 'images/forest.jpg');

// Create file metadata to update
const newMetadata = {
  cacheControl: 'public,max-age=300',
  contentType: 'image/jpeg'
};

// Update metadata properties
updateMetadata(forestRef, newMetadata)
  .then((metadata) => {
    // Updated metadata for 'images/forest.jpg' is returned in the Promise
  }).catch((error) => {
    // Uh-oh, an error occurred!
  });

Web

// Create a reference to the file whose metadata we want to change
var forestRef = storageRef.child('images/forest.jpg');

// Create file metadata to update
var newMetadata = {
  cacheControl: 'public,max-age=300',
  contentType: 'image/jpeg'
};

// Update metadata properties
forestRef.updateMetadata(newMetadata)
  .then((metadata) => {
    // Updated metadata for 'images/forest.jpg' is returned in the Promise
  }).catch((error) => {
    // Uh-oh, an error occurred!
  });

আপনি null এ সেট করে একটি মেটাডেটা বৈশিষ্ট্য মুছে ফেলতে পারেন:

Web

import { getStorage, ref, updateMetadata } from "firebase/storage";

const storage = getStorage();
const forestRef = ref(storage, 'images/forest.jpg');

// Create file metadata with property to delete
const deleteMetadata = {
  contentType: null
};

// Delete the metadata property
updateMetadata(forestRef, deleteMetadata)
  .then((metadata) => {
    // metadata.contentType should be null
  }).catch((error) => {
    // Uh-oh, an error occurred!
  });

Web

// Create file metadata with property to delete
var deleteMetadata = {
  contentType: null
};

// Delete the metadata property
forestRef.updateMetadata(deleteMetadata)
  .then((metadata) => {
    // metadata.contentType should be null
  }).catch((error) => {
    // Uh-oh, an error occurred!
  });

হ্যান্ডেল ত্রুটি

মেটাডেটা পাওয়া বা আপডেট করার সময় ত্রুটি ঘটতে পারে এমন অনেক কারণ থাকতে পারে, যার মধ্যে রয়েছে ফাইলটি বিদ্যমান না থাকা, অথবা ব্যবহারকারীর পছন্দসই ফাইলটি অ্যাক্সেস করার অনুমতি না থাকা। ত্রুটি সম্পর্কে আরও তথ্য ডক্সের "হ্যান্ডেল এররস" বিভাগে পাওয়া যাবে।

কাস্টম মেটাডেটা

আপনি String বৈশিষ্ট্য ধারণকারী একটি বস্তু হিসাবে কাস্টম মেটাডেটা নির্দিষ্ট করতে পারেন।

Web

const metadata = {
  customMetadata: {
    'location': 'Yosemite, CA, USA',
    'activity': 'Hiking'
  }
};

Web

var metadata = {
  customMetadata: {
    'location': 'Yosemite, CA, USA',
    'activity': 'Hiking'
  }
};

প্রতিটি ফাইলের জন্য অতিরিক্ত অ্যাপ-নির্দিষ্ট ডেটা সংরক্ষণের জন্য আপনি কাস্টম মেটাডেটা ব্যবহার করতে পারেন, তবে আমরা এই ধরণের ডেটা সংরক্ষণ এবং সিঙ্ক্রোনাইজ করার জন্য একটি ডাটাবেস (যেমন Firebase Realtime Database ) ব্যবহার করার পরামর্শ দিচ্ছি।

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

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

সম্পত্তি আদর্শ লেখার যোগ্য
bucket স্ট্রিং না
generation স্ট্রিং না
metageneration স্ট্রিং না
fullPath স্ট্রিং না
name স্ট্রিং না
size সংখ্যা না
timeCreated স্ট্রিং না
updated স্ট্রিং না
md5Hash স্ট্রিং আপলোডে হ্যাঁ, আপডেটমেটাডেটাতে না
cacheControl স্ট্রিং হ্যাঁ
contentDisposition স্ট্রিং হ্যাঁ
contentEncoding স্ট্রিং হ্যাঁ
contentLanguage স্ট্রিং হ্যাঁ
contentType স্ট্রিং হ্যাঁ
customMetadata স্ট্রিং->স্ট্রিং ম্যাপিং ধারণকারী অবজেক্ট হ্যাঁ

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