تحميل الملفات باستخدام Cloud Storage لبرنامج Unity

يتيح لك Cloud Storage for Firebase تحميل الملفات بسرعة وسهولة إلى حزمة Cloud Storage يوفّرها ويديرها Firebase.

إنشاء مرجع

لتحميل ملف، عليك أولاً إنشاء Cloud Storage مرجع للملف الذي تريد تحميله.

يمكنك إنشاء مرجع من خلال إلحاق المسارات الفرعية بجذر حزمة Cloud Storage، أو يمكنك إنشاء مرجع من عنوان URL حالي لملف gs:// أو https:// يشير إلى عنصر في Cloud Storage.

// Create a root reference
StorageReference storageRef = storage.RootReference;

// Create a reference to "mountains.jpg"
StorageReference mountainsRef = storageRef.Child("mountains.jpg");

// Create a reference to 'images/mountains.jpg'
StorageReference mountainImagesRef =
    storageRef.Child("images/mountains.jpg");

// While the file names are the same, the references point to different files
Assert.AreEqual(mountainsRef.Name, mountainImagesRef.Name);
Assert.AreNotEqual(mountainsRef.Path, mountainImagesRef.Path);

لا يمكنك تحميل بيانات تتضمّن إشارة إلى جذر حزمة Cloud Storage. يجب أن يشير المرجع إلى عنوان URL فرعي.

تحميل ملفات

بعد الحصول على مرجع، يمكنك تحميل الملفات إلى Cloud Storage بطريقتَين:

  1. التحميل من صفيف بايت في الذاكرة
  2. التحميل من مسار ملف يمثّل ملفًا على الجهاز

التحميل من البيانات في الذاكرة

تشكّل الطريقة PutBytesAsync() أبسط طريقة لتحميل ملف إلى Cloud Storage. تأخذ دالة PutBytesAsync() ‎byte[] وتُرجع System.Task<Firebase.Storage.StorageMetadata> التي ستشكل معلومات عن الملف عند اكتمال المهمة. يمكنك اختياريًا استخدام IProgress<UploadState> (عادةً StorageProgress<UploadState>) لتتبّع حالة التحميل.

// Data in memory
var customBytes = new byte[] {
    /*...*/
};

// Create a reference to the file you want to upload
StorageReference riversRef = storageRef.Child("images/rivers.jpg");

// Upload the file to the path "images/rivers.jpg"
riversRef.PutBytesAsync(customBytes)
    .ContinueWith((Task<StorageMetadata> task) => {
        if (task.IsFaulted || task.IsCanceled) {
            Debug.Log(task.Exception.ToString());
            // Uh-oh, an error occurred!
        }
        else {
            // Metadata contains file metadata such as size, content-type, and md5hash.
            StorageMetadata metadata = task.Result;
            string md5Hash = metadata.Md5Hash;
            Debug.Log("Finished uploading...");
            Debug.Log("md5 hash = " + md5Hash);
        }
    });

التحميل من ملف على الجهاز

يمكنك تحميل الملفات على الأجهزة، مثل الصور والفيديوهات من الكاميرا، باستخدام طريقة PutFileAsync(). تأخذ دالة PutFileAsync() string الذي يمثّل مسار الملف وتُعرِضSystem.Task<Firebase.Storage.StorageMetadata> الذي سيحتوي على معلومات عن الملف عند اكتمال المهمة. يمكنك اختياريًا استخدام IProgress<UploadState> (عادةً StorageProgress<UploadState>) لتتبّع حالة التحميل.

// File located on disk
string localFile = "...";

// Create a reference to the file you want to upload
StorageReference riversRef = storageRef.Child("images/rivers.jpg");

// Upload the file to the path "images/rivers.jpg"
riversRef.PutFileAsync(localFile)
    .ContinueWith((Task<StorageMetadata> task) => {
        if (task.IsFaulted || task.IsCanceled) {
            Debug.Log(task.Exception.ToString());
            // Uh-oh, an error occurred!
        }
        else {
            // Metadata contains file metadata such as size, content-type, and download URL.
            StorageMetadata metadata = task.Result;
            string md5Hash = metadata.Md5Hash;
            Debug.Log("Finished uploading...");
            Debug.Log("md5 hash = " + md5Hash);
        }
    });

إذا كنت تريد مراقبة عملية التحميل بشكل نشط، يمكنك استخدام StorageProgress صف أو صفك الخاص الذي ينفِّذ IProgress<UploadState>، مع استخدام الطريقتَين PutFileAsync() أو PutBytesAsync(). اطّلِع على إدارة عمليات التحميل للحصول على مزيد من المعلومات.

إضافة البيانات الوصفية للملف

يمكنك أيضًا تضمين البيانات الوصفية عند تحميل الملفات. تحتوي هذه البيانات الوصفية على سمات البيانات الوصفية للملف النموذجية، مثل Name وSize وContentType (المعروفة عادةً باسم نوع MIME). تستنتج طريقة PutFileAsync() تلقائيًا نوع المحتوى من امتداد اسم الملف، ولكن يمكنك إلغاء نوع المحتوى الذي تم رصده تلقائيًا من خلال تحديد ContentType في البيانات الوصفية. إذا لم يتم تقديم ContentType ولم يتمكّن Cloud Storage من استنتاج قيمة تلقائية من امتداد الملف، سيستخدم Cloud Storage application/octet-stream. راجِع القسم استخدام البيانات الوصفية للملف للحصول على مزيد من المعلومات عن البيانات الوصفية للملف.

// Create storage reference
StorageReference mountainsRef = storageRef.Child("images/mountains.jpg");

byte[] customBytes = new byte[] {
    /*...*/
};
string localFile = "...";

// Create file metadata including the content type
var newMetadata = new MetadataChange();
newMetadata.ContentType = "image/jpeg";

// Upload data and metadata
mountainsRef.PutBytesAsync(customBytes, newMetadata, null,
    CancellationToken.None); // .ContinueWithOnMainThread(...
// Upload file and metadata
mountainsRef.PutFileAsync(localFile, newMetadata, null,
    CancellationToken.None); // .ContinueWithOnMainThread(...

تتبُّع مستوى تقدُّم عملية التحميل

يمكنك إرفاق مستمعين بالتحميلات من أجل تتبُّع مستوى تقدّم التحميل. يتبع المستمع واجهة System.IProgress<T> المعيار. يمكنك استخدام مثيل من فئة StorageProgress لتوفير Action<T> الخاص بك كإجراء استدعاء لعلامات التقدّم.

// Start uploading a file
var task = storageRef.Child("images/mountains.jpg")
    .PutFileAsync(localFile, null,
        new StorageProgress<UploadState>(state => {
            // called periodically during the upload
            Debug.Log(String.Format("Progress: {0} of {1} bytes transferred.",
                state.BytesTransferred, state.TotalByteCount));
        }), CancellationToken.None, null);

task.ContinueWithOnMainThread(resultTask => {
    if (!resultTask.IsFaulted && !resultTask.IsCanceled) {
        Debug.Log("Upload finished.");
    }
});

خطأ أثناء المعالجة

هناك عدد من الأسباب التي قد تؤدي إلى حدوث أخطاء أثناء التحميل، بما في ذلك عدم توفّر الملف على الجهاز أو عدم توفّر إذن لدى المستخدم لتحميل الملف المطلوب. يمكنك العثور على مزيد من المعلومات حول الأخطاء في قسم معالجة الأخطاء في المستندات.

الخطوات التالية

بعد تحميل الملفات، لنتعرّف على كيفية تنزيلها من Cloud Storage.