สร้างข้อมูลอ้างอิงของ Cloud Storage บน Android
จัดทุกอย่างให้เป็นระเบียบอยู่เสมอด้วยคอลเล็กชัน
บันทึกและจัดหมวดหมู่เนื้อหาตามค่ากำหนดของคุณ
ระบบจะจัดเก็บไฟล์ไว้ในที่เก็บข้อมูล
Cloud Storage
ไฟล์ในที่เก็บข้อมูลนี้จะแสดงในโครงสร้างแบบลำดับชั้น เช่นเดียวกับ
ระบบไฟล์ในฮาร์ดดิสก์ในเครื่อง หรือข้อมูลใน Firebase Realtime Database
การสร้างการอ้างอิงถึงไฟล์จะทำให้แอปของคุณมีสิทธิ์เข้าถึงไฟล์นั้น จากนั้นคุณจะใช้ข้อมูลอ้างอิงเหล่านี้เพื่ออัปโหลดหรือดาวน์โหลดข้อมูล รับหรืออัปเดตข้อมูลเมตา หรือลบไฟล์ได้ การอ้างอิงอาจชี้ไปยังไฟล์ที่เฉพาะเจาะจงหรือไปยังโหนดระดับที่สูงกว่า
ในลำดับชั้นก็ได้
หากคุณเคยใช้ Firebase Realtime Database เส้นทางเหล่านี้จะ
ดูคุ้นเคยเป็นอย่างยิ่ง อย่างไรก็ตาม ข้อมูลไฟล์จะจัดเก็บไว้ใน Cloud Storage ไม่ใช่ใน Realtime Database
สร้างการอ้างอิง
สร้างการอ้างอิงเพื่ออัปโหลด ดาวน์โหลด หรือลบไฟล์
หรือเพื่อรับหรืออัปเดตข้อมูลเมตาของไฟล์ คุณสามารถคิดว่าการอ้างอิง
เป็นตัวชี้ไปยังไฟล์ในระบบคลาวด์ การอ้างอิงมีขนาดเล็ก คุณจึงสร้างได้มากเท่าที่ต้องการ และยังใช้ซ้ำได้สำหรับการดำเนินการหลายอย่าง
สร้างการอ้างอิงโดยใช้FirebaseStorage
อินสแตนซ์ Singleton และ
เรียกใช้เมธอด 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()
จะเลื่อนขึ้นไป 1 ระดับ
ส่วน 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กัน
เนื้อหาของหน้าเว็บนี้ได้รับอนุญาตภายใต้ใบอนุญาตที่ต้องระบุที่มาของครีเอทีฟคอมมอนส์ 4.0 และตัวอย่างโค้ดได้รับอนุญาตภายใต้ใบอนุญาต Apache 2.0 เว้นแต่จะระบุไว้เป็นอย่างอื่น โปรดดูรายละเอียดที่นโยบายเว็บไซต์ Google Developers Java เป็นเครื่องหมายการค้าจดทะเบียนของ Oracle และ/หรือบริษัทในเครือ
อัปเดตล่าสุด 2025-08-21 UTC
[null,null,["อัปเดตล่าสุด 2025-08-21 UTC"],[],[],null,["\u003cbr /\u003e\n\nYour files are stored in a\n[Cloud Storage](//cloud.google.com/storage) bucket. The\nfiles in this bucket are presented in a hierarchical structure, just like the\nfile system on your local hard disk, or the data in the Firebase Realtime Database.\nBy creating a reference to a file, your app gains access to it. These references\ncan then be used to upload or download data, get or update metadata or delete\nthe file. A reference can either point to a specific file or to a higher level\nnode in the hierarchy.\n\nIf you've used the [Firebase Realtime Database](/docs/database), these paths should\nseem very familiar to you. However, your file data is stored in\nCloud Storage, **not** in the Realtime Database.\n\nCreate a Reference\n\nCreate a reference to upload, download, or delete a file,\nor to get or update its metadata. A reference\ncan be thought of as a pointer to a file in the cloud. References are\nlightweight, so you can create as many as you need. They are also reusable for\nmultiple operations.\n\nCreate a reference using the `FirebaseStorage` singleton instance and\ncalling its `getReference()` method. \n\nKotlin \n\n```kotlin\n// Create a storage reference from our app\nvar storageRef = storage.reference \nhttps://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L49-L50\n```\n\nJava \n\n```java\n// Create a storage reference from our app\nStorageReference storageRef = storage.getReference();https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L78-L79\n```\n\nNext, you can create a reference to a location lower in the tree,\nsay `\"images/space.jpg\"` by using the `child()` method on an existing reference. \n\nKotlin \n\n```kotlin\n// Create a child reference\n// imagesRef now points to \"images\"\nvar imagesRef: StorageReference? = storageRef.child(\"images\")\n\n// Child references can also take paths\n// spaceRef now points to \"images/space.jpg\n// imagesRef still points to \"images\"\nvar spaceRef = storageRef.child(\"images/space.jpg\")https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L54-L61\n```\n\nJava \n\n```java\n// Create a child reference\n// imagesRef now points to \"images\"\nStorageReference imagesRef = storageRef.child(\"images\");\n\n// Child references can also take paths\n// spaceRef now points to \"images/space.jpg\n// imagesRef still points to \"images\"\nStorageReference spaceRef = storageRef.child(\"images/space.jpg\");https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L83-L90\n```\n\nNavigate with References\n\nYou can also use the `getParent()` and `getRoot()` methods to navigate up in our\nfile hierarchy. `getParent()` navigates up one level,\nwhile `getRoot()` navigates all the way to the top. \n\nKotlin \n\n```kotlin\n// parent allows us to move our reference to a parent node\n// imagesRef now points to 'images'\nimagesRef = spaceRef.parent\n\n// root allows us to move all the way back to the top of our bucket\n// rootRef now points to the root\nval rootRef = spaceRef.root \nhttps://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L67-L73\n```\n\nJava \n\n```java\n// getParent allows us to move our reference to a parent node\n// imagesRef now points to 'images'\nimagesRef = spaceRef.getParent();\n\n// getRoot allows us to move all the way back to the top of our bucket\n// rootRef now points to the root\nStorageReference rootRef = spaceRef.getRoot();https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L96-L102\n```\n\n`child()`, `getParent()`, and `getRoot()` can be chained together multiple\ntimes, as each returns a reference. But calling `getRoot().getParent()` returns `null`. \n\nKotlin \n\n```kotlin\n// References can be chained together multiple times\n// earthRef points to 'images/earth.jpg'\nval earthRef = spaceRef.parent?.child(\"earth.jpg\")\n\n// nullRef is null, since the parent of root is null\nval nullRef = spaceRef.root.parent \nhttps://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L77-L82\n```\n\nJava \n\n```java\n// References can be chained together multiple times\n// earthRef points to 'images/earth.jpg'\nStorageReference earthRef = spaceRef.getParent().child(\"earth.jpg\");\n\n// nullRef is null, since the parent of root is null\nStorageReference nullRef = spaceRef.getRoot().getParent();https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L106-L111\n```\n\nReference Properties\n\nYou can inspect references to better understand the files they point to\nusing the `getPath()`, `getName()`, and `getBucket()` methods. These methods\nget the file's full path, name and bucket. \n\nKotlin \n\n```kotlin\n// Reference's path is: \"images/space.jpg\"\n// This is analogous to a file path on disk\nspaceRef.path\n\n// Reference's name is the last segment of the full path: \"space.jpg\"\n// This is analogous to the file name\nspaceRef.name\n\n// Reference's bucket is the name of the storage bucket that the files are stored in\nspaceRef.bucket \nhttps://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L88-L97\n```\n\nJava \n\n```java\n// Reference's path is: \"images/space.jpg\"\n// This is analogous to a file path on disk\nspaceRef.getPath();\n\n// Reference's name is the last segment of the full path: \"space.jpg\"\n// This is analogous to the file name\nspaceRef.getName();\n\n// Reference's bucket is the name of the storage bucket that the files are stored in\nspaceRef.getBucket();https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L117-L126\n```\n\nLimitations on References\n\nReference paths and names can contain any sequence of valid Unicode characters,\nbut certain restrictions are imposed including:\n\n1. Total length of reference.fullPath must be between 1 and 1024 bytes when UTF-8 encoded.\n2. No Carriage Return or Line Feed characters.\n3. Avoid using `#`, `[`, `]`, `*`, or `?`, as these do not work well with other tools such as the [Firebase Realtime Database](/docs/database) or [gsutil](https://cloud.google.com/storage/docs/gsutil).\n\nFull Example \n\nKotlin \n\n```kotlin\n// Points to the root reference\nstorageRef = storage.reference\n\n// Points to \"images\"\nimagesRef = storageRef.child(\"images\")\n\n// Points to \"images/space.jpg\"\n// Note that you can use variables to create child values\nval fileName = \"space.jpg\"\nspaceRef = imagesRef.child(fileName)\n\n// File path is \"images/space.jpg\"\nval path = spaceRef.path\n\n// File name is \"space.jpg\"\nval name = spaceRef.name\n\n// Points to \"images\"\nimagesRef = spaceRef.parent \nhttps://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/kotlin/StorageActivity.kt#L103-L121\n```\n\nJava \n\n```java\n// Points to the root reference\nstorageRef = storage.getReference();\n\n// Points to \"images\"\nimagesRef = storageRef.child(\"images\");\n\n// Points to \"images/space.jpg\"\n// Note that you can use variables to create child values\nString fileName = \"space.jpg\";\nspaceRef = imagesRef.child(fileName);\n\n// File path is \"images/space.jpg\"\nString path = spaceRef.getPath();\n\n// File name is \"space.jpg\"\nString name = spaceRef.getName();\n\n// Points to \"images\"\nimagesRef = spaceRef.getParent();https://github.com/firebase/snippets-android/blob/391c1646eacf44d2aab3f76bcfa60dfc6c14acf1/storage/app/src/main/java/com/google/firebase/referencecode/storage/StorageActivity.java#L132-L150\n```\n\nNext, let's learn how to\n[upload files](/docs/storage/android/upload-files) to\nCloud Storage."]]