يتم تخزين ملفاتك في حزمة Cloud Storage. يتم عرض الملفات في هذه الحزمة في بنية هرمية، تمامًا مثل نظام الملفات على القرص الثابت المحلي أو البيانات في Firebase Realtime Database. من خلال إنشاء مرجع لملف، يمكن لتطبيقك الوصول إليه. ويمكن استخدام هذه المراجع لتحميل البيانات أو تنزيلها أو الحصول على البيانات الوصفية أو تعديلها أو حذف الملف. يمكن أن يشير المرجع إلى ملف معيّن أو إلى عقدة ذات مستوى أعلى في التدرّج الهرمي.
إذا سبق لك استخدام Firebase Realtime Database، من المفترض أن تكون هذه المسارات مألوفة جدًا بالنسبة إليك. ومع ذلك، يتم تخزين بيانات ملفاتك في Cloud Storage، وليس في Realtime Database.
إنشاء مرجع
إنشاء مرجع لتحميل ملف أو تنزيله أو حذفه، أو للحصول على البيانات الوصفية الخاصة به أو تعديلها يمكن اعتبار المرجع مؤشرًا إلى ملف في السحابة الإلكترونية. المراجع بسيطة، لذا يمكنك إنشاء العدد الذي تحتاجه منها. ويمكن أيضًا إعادة استخدامها في عمليات متعددة.
أنشئ مرجعًا باستخدام مثيل FirebaseStorage
الفردي واستدعِ طريقة getReference()
.
Kotlin
// Create a storage reference from our app var storageRef = storage.reference
Java
// Create a storage reference from our app StorageReference storageRef = storage.getReference();
بعد ذلك، يمكنك إنشاء مرجع إلى موقع جغرافي أدنى في الشجرة،
على سبيل المثال "images/space.jpg"
، باستخدام طريقة child()
على مرجع حالي.
Kotlin
// Create a child reference // imagesRef now points to "images" var imagesRef: StorageReference? = storageRef.child("images") // Child references can also take paths // spaceRef now points to "images/space.jpg // imagesRef still points to "images" var spaceRef = storageRef.child("images/space.jpg")
Java
// Create a child reference // imagesRef now points to "images" StorageReference imagesRef = storageRef.child("images"); // Child references can also take paths // spaceRef now points to "images/space.jpg // imagesRef still points to "images" StorageReference spaceRef = storageRef.child("images/space.jpg");
التنقّل باستخدام "المراجع"
يمكنك أيضًا استخدام الطريقتَين getParent()
وgetRoot()
للتنقّل للأعلى في التسلسل الهرمي للملفات. يؤدي الضغط على getParent()
إلى الانتقال إلى مستوى أعلى واحد،
بينما يؤدي الضغط على getRoot()
إلى الانتقال إلى أعلى مستوى.
Kotlin
// parent allows us to move our reference to a parent node // imagesRef now points to 'images' imagesRef = spaceRef.parent // root allows us to move all the way back to the top of our bucket // rootRef now points to the root val rootRef = spaceRef.root
Java
// getParent allows us to move our reference to a parent node // imagesRef now points to 'images' imagesRef = spaceRef.getParent(); // getRoot allows us to move all the way back to the top of our bucket // rootRef now points to the root StorageReference rootRef = spaceRef.getRoot();
يمكن ربط child()
وgetParent()
وgetRoot()
معًا عدة مرات، لأنّ كلّ منها يعرض مرجعًا. ولكن عند الاتصال بالرقم getRoot().getParent()
، يتم عرض الرقم null
.
Kotlin
// References can be chained together multiple times // earthRef points to 'images/earth.jpg' val earthRef = spaceRef.parent?.child("earth.jpg") // nullRef is null, since the parent of root is null val nullRef = spaceRef.root.parent
Java
// References can be chained together multiple times // earthRef points to 'images/earth.jpg' StorageReference earthRef = spaceRef.getParent().child("earth.jpg"); // nullRef is null, since the parent of root is null StorageReference nullRef = spaceRef.getRoot().getParent();
الخصائص المرجعية
يمكنك فحص المراجع لفهم الملفات التي تشير إليها بشكل أفضل باستخدام الطرق getPath()
وgetName()
وgetBucket()
. تسترد هذه الطرق المسار الكامل للملف واسمه وحزمة التخزين.
Kotlin
// Reference's path is: "images/space.jpg" // This is analogous to a file path on disk spaceRef.path // Reference's name is the last segment of the full path: "space.jpg" // This is analogous to the file name spaceRef.name // Reference's bucket is the name of the storage bucket that the files are stored in spaceRef.bucket
Java
// Reference's path is: "images/space.jpg" // This is analogous to a file path on disk spaceRef.getPath(); // Reference's name is the last segment of the full path: "space.jpg" // This is analogous to the file name spaceRef.getName(); // Reference's bucket is the name of the storage bucket that the files are stored in spaceRef.getBucket();
القيود المفروضة على المراجع
يمكن أن تحتوي مسارات المراجع وأسماؤها على أي تسلسل من أحرف Unicode الصالحة، ولكن يتم فرض قيود معيّنة، بما في ذلك:
- يجب أن يتراوح إجمالي طول reference.fullPath بين 1 و1024 بايت عند استخدام ترميز UTF-8.
- يجب عدم استخدام أحرف الرجوع إلى أول السطر أو نهاية السطر.
- تجنَّب استخدام
#
أو[
أو]
أو*
أو?
، لأنّها لا تعمل بشكل جيد مع أدوات أخرى، مثل Firebase Realtime Database أو gsutil.
مثال كامل
Kotlin
// Points to the root reference storageRef = storage.reference // Points to "images" imagesRef = storageRef.child("images") // Points to "images/space.jpg" // Note that you can use variables to create child values val fileName = "space.jpg" spaceRef = imagesRef.child(fileName) // File path is "images/space.jpg" val path = spaceRef.path // File name is "space.jpg" val name = spaceRef.name // Points to "images" imagesRef = spaceRef.parent
Java
// Points to the root reference storageRef = storage.getReference(); // Points to "images" imagesRef = storageRef.child("images"); // Points to "images/space.jpg" // Note that you can use variables to create child values String fileName = "space.jpg"; spaceRef = imagesRef.child(fileName); // File path is "images/space.jpg" String path = spaceRef.getPath(); // File name is "space.jpg" String name = spaceRef.getName(); // Points to "images" imagesRef = spaceRef.getParent();
بعد ذلك، سنتعرّف على كيفية تحميل الملفات إلى Cloud Storage.