สร้างข้อมูลอ้างอิงของ Cloud Storage บนเว็บ
จัดทุกอย่างให้เป็นระเบียบอยู่เสมอด้วยคอลเล็กชัน
บันทึกและจัดหมวดหมู่เนื้อหาตามค่ากำหนดของคุณ
ระบบจะจัดเก็บไฟล์ไว้ในที่เก็บข้อมูล
Cloud Storage
ไฟล์ในที่เก็บข้อมูลนี้จะแสดงในโครงสร้างแบบลำดับชั้น เช่นเดียวกับ
ระบบไฟล์ในฮาร์ดดิสก์ในเครื่อง หรือข้อมูลใน Firebase Realtime Database
การสร้างการอ้างอิงถึงไฟล์จะทำให้แอปของคุณมีสิทธิ์เข้าถึงไฟล์นั้น จากนั้นคุณจะใช้ข้อมูลอ้างอิงเหล่านี้เพื่ออัปโหลดหรือดาวน์โหลดข้อมูล รับหรืออัปเดตข้อมูลเมตา หรือลบไฟล์ได้ การอ้างอิงอาจชี้ไปยังไฟล์ที่เฉพาะเจาะจงหรือไปยังโหนดระดับที่สูงกว่า
ในลำดับชั้นก็ได้
หากคุณเคยใช้ Firebase Realtime Database เส้นทางเหล่านี้จะ
ดูคุ้นเคยเป็นอย่างยิ่ง อย่างไรก็ตาม ข้อมูลไฟล์จะจัดเก็บไว้ใน Cloud Storage ไม่ใช่ใน Realtime Database
สร้างการอ้างอิง
หากต้องการอัปโหลดหรือดาวน์โหลดไฟล์ ลบไฟล์ หรือรับหรืออัปเดตข้อมูลเมตา
คุณต้องสร้างการอ้างอิงไปยังไฟล์ที่ต้องการดำเนินการ คุณสามารถคิดว่าการอ้างอิง
เป็นตัวชี้ไปยังไฟล์ในระบบคลาวด์ การอ้างอิงมีขนาดเล็ก คุณจึงสร้างได้มากเท่าที่ต้องการ และยังนำไปใช้ซ้ำได้สำหรับการดำเนินการหลายอย่าง
หากต้องการสร้างการอ้างอิง ให้รับอินสแตนซ์ของบริการ Storage โดยใช้
getStorage()
จากนั้นเรียกใช้ ref()
โดยมีบริการเป็นอาร์กิวเมนต์
การอ้างอิงนี้ชี้ไปยังรูทของที่เก็บข้อมูล Cloud Storage
Web
import { getStorage, ref } from "firebase/storage";
// Get a reference to the storage service, which is used to create references in your storage bucket
const storage = getStorage();
// Create a storage reference from our storage service
const storageRef = ref(storage);
Web
// Get a reference to the storage service, which is used to create references in your storage bucket
var storage = firebase.storage();
// Create a storage reference from our storage service
var storageRef = storage.ref();
คุณสร้างการอ้างอิงไปยังตำแหน่งที่ต่ำกว่าในโครงสร้างได้
เช่น 'images/space.jpg'
โดยส่งเส้นทางนี้เป็นอาร์กิวเมนต์ที่สองเมื่อ
เรียกใช้ ref()
Web
import { getStorage, ref } from "firebase/storage";
const storage = getStorage();
// Create a child reference
const imagesRef = ref(storage, 'images');
// imagesRef now points to 'images'
// Child references can also take paths delimited by '/'
const spaceRef = ref(storage, 'images/space.jpg');
// spaceRef now points to "images/space.jpg"
// imagesRef still points to "images"
Web
// Create a child reference
var imagesRef = storageRef.child('images');
// imagesRef now points to 'images'
// Child references can also take paths delimited by '/'
var spaceRef = storageRef.child('images/space.jpg');
// spaceRef now points to "images/space.jpg"
// imagesRef still points to "images"
ไปยังส่วนต่างๆ ด้วยการอ้างอิง
นอกจากนี้ คุณยังใช้พร็อพเพอร์ตี้ parent
และ root
เพื่อไปยังระดับบนสุดของ
ลำดับชั้นของไฟล์ได้ด้วย parent
จะเลื่อนขึ้นไป 1 ระดับ
ส่วน root
จะเลื่อนขึ้นไปจนถึงระดับบนสุด
Web
import { getStorage, ref } from "firebase/storage";
const storage = getStorage();
const spaceRef = ref(storage, 'images/space.jpg');
// Parent allows us to move to the parent of a reference
const imagesRef = spaceRef.parent;
// imagesRef now points to 'images'
// Root allows us to move all the way back to the top of our bucket
const rootRef = spaceRef.root;
// rootRef now points to the root
Web
// Parent allows us to move to the parent of a reference
var imagesRef = spaceRef.parent;
// imagesRef now points to 'images'
// Root allows us to move all the way back to the top of our bucket
var rootRef = spaceRef.root;
// rootRef now points to the root
child()
, parent
และ root
สามารถเชื่อมต่อกันได้หลายครั้ง เนื่องจากแต่ละรายการจะแสดงผลการอ้างอิง ข้อยกเว้นคือ parent
ของ root
ซึ่ง
คือ null
Web
import { getStorage, ref } from "firebase/storage";
const storage = getStorage();
const spaceRef = ref(storage, 'images/space.jpg');
// References can be chained together multiple times
const earthRef = ref(spaceRef.parent, 'earth.jpg');
// earthRef points to 'images/earth.jpg'
// nullRef is null, since the parent of root is null
const nullRef = spaceRef.root.parent;
Web
// References can be chained together multiple times
var earthRef = spaceRef.parent.child('earth.jpg');
// earthRef points to 'images/earth.jpg'
// nullRef is null, since the parent of root is null
var nullRef = spaceRef.root.parent;
พร็อพเพอร์ตี้อ้างอิง
คุณสามารถตรวจสอบการอ้างอิงเพื่อให้เข้าใจไฟล์ที่อ้างอิงได้ดียิ่งขึ้น
โดยใช้พร็อพเพอร์ตี้ fullPath
, name
และ bucket
พร็อพเพอร์ตี้เหล่านี้
จะรับเส้นทางแบบเต็มของไฟล์ ชื่อไฟล์
และที่เก็บข้อมูลที่จัดเก็บไฟล์
Web
import { getStorage, ref } from "firebase/storage";
const storage = getStorage();
const spaceRef = ref(storage, 'images/space.jpg');
// Reference's path is: 'images/space.jpg'
// This is analogous to a file path on disk
spaceRef.fullPath;
// 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 where files are stored
spaceRef.bucket;
Web
// Reference's path is: 'images/space.jpg'
// This is analogous to a file path on disk
spaceRef.fullPath;
// 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 where files are stored
spaceRef.bucket;
ข้อจำกัดในการอ้างอิง
เส้นทางและชื่ออ้างอิงอาจมีลำดับอักขระ Unicode ที่ถูกต้องใดก็ได้
แต่จะมีข้อจำกัดบางอย่าง ได้แก่
- ความยาวรวมของ
reference.fullPath
ต้องอยู่ระหว่าง 1 ถึง 1024 ไบต์เมื่อเข้ารหัส UTF-8
- ไม่มีอักขระขึ้นบรรทัดใหม่หรืออักขระตัดบรรทัด
- หลีกเลี่ยงการใช้
#
, [
, ]
, *
หรือ ?
เนื่องจากเครื่องมือเหล่านี้ทำงานร่วมกับ
เครื่องมืออื่นๆ เช่น Firebase Realtime Database
หรือ gsutil ได้ไม่ดี
ตัวอย่างแบบเต็ม
Web
import { getStorage, ref } from "firebase/storage";
const storage = getStorage();
// Points to the root reference
const storageRef = ref(storage);
// Points to 'images'
const imagesRef = ref(storageRef, 'images');
// Points to 'images/space.jpg'
// Note that you can use variables to create child values
const fileName = 'space.jpg';
const spaceRef = ref(imagesRef, fileName);
// File path is 'images/space.jpg'
const path = spaceRef.fullPath;
// File name is 'space.jpg'
const name = spaceRef.name;
// Points to 'images'
const imagesRefAgain = spaceRef.parent;
Web
// Points to the root reference
var storageRef = firebase.storage().ref();
// Points to 'images'
var imagesRef = storageRef.child('images');
// Points to 'images/space.jpg'
// Note that you can use variables to create child values
var fileName = 'space.jpg';
var spaceRef = imagesRef.child(fileName);
// File path is 'images/space.jpg'
var path = spaceRef.fullPath;
// File name is 'space.jpg'
var name = spaceRef.name;
// Points to 'images'
var imagesRef = spaceRef.parent;
ถัดไป เราจะมาดูวิธี
อัปโหลดไฟล์ไปยัง
Cloud Storageกัน
เนื้อหาของหน้าเว็บนี้ได้รับอนุญาตภายใต้ใบอนุญาตที่ต้องระบุที่มาของครีเอทีฟคอมมอนส์ 4.0 และตัวอย่างโค้ดได้รับอนุญาตภายใต้ใบอนุญาต Apache 2.0 เว้นแต่จะระบุไว้เป็นอย่างอื่น โปรดดูรายละเอียดที่นโยบายเว็บไซต์ Google Developers Java เป็นเครื่องหมายการค้าจดทะเบียนของ Oracle และ/หรือบริษัทในเครือ
อัปเดตล่าสุด 2025-08-08 UTC
[null,null,["อัปเดตล่าสุด 2025-08-08 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\nIn order to upload or download files, delete files, or get or update metadata,\nyou must create a reference to the file you want to operate on. 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, and they are also reusable for\nmultiple operations.\n\nTo create a reference, get an instance of the Storage service using\n`getStorage()` then call `ref()` with the service as an argument.\nThis reference points to the root of your Cloud Storage bucket. \n\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\n// Get a reference to the storage service, which is used to create references in your storage bucket\nconst storage = getStorage();\n\n// Create a storage reference from our storage service\nconst storageRef = ref(storage);https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_create_ref.js#L8-L14\n```\n\nWeb \n\n```javascript\n// Get a reference to the storage service, which is used to create references in your storage bucket\nvar storage = firebase.storage();\n\n// Create a storage reference from our storage service\nvar storageRef = storage.ref();https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L6-L10\n```\n\nYou can create a reference to a location lower in the tree,\nsay `'images/space.jpg'` by passing in this path as a second argument when\ncalling `ref()`. \n\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\nconst storage = getStorage();\n\n// Create a child reference\nconst imagesRef = ref(storage, 'images');\n// imagesRef now points to 'images'\n\n// Child references can also take paths delimited by '/'\nconst spaceRef = ref(storage, 'images/space.jpg');\n// spaceRef now points to \"images/space.jpg\"\n// imagesRef still points to \"images\" \nhttps://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_create_ref_child.js#L8-L19\n```\n\nWeb \n\n```javascript\n// Create a child reference\nvar imagesRef = storageRef.child('images');\n// imagesRef now points to 'images'\n\n// Child references can also take paths delimited by '/'\nvar spaceRef = storageRef.child('images/space.jpg');\n// spaceRef now points to \"images/space.jpg\"\n// imagesRef still points to \"images\" \nhttps://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L18-L25\n```\n\nNavigate with References\n\nYou can also use the `parent` and `root` properties to navigate up the\nfile hierarchy. `parent` navigates up one level,\nwhile `root` navigates all the way to the top. \n\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\nconst storage = getStorage();\nconst spaceRef = ref(storage, 'images/space.jpg');\n\n// Parent allows us to move to the parent of a reference\nconst imagesRef = spaceRef.parent;\n// imagesRef now points to 'images'\n\n// Root allows us to move all the way back to the top of our bucket\nconst rootRef = spaceRef.root;\n// rootRef now points to the root \nhttps://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_navigate_ref.js#L8-L19\n```\n\nWeb \n\n```javascript\n// Parent allows us to move to the parent of a reference\nvar imagesRef = spaceRef.parent;\n// imagesRef now points to 'images'\n\n// Root allows us to move all the way back to the top of our bucket\nvar rootRef = spaceRef.root;\n// rootRef now points to the root \nhttps://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L33-L39\n```\n\n`child()`, `parent`, and `root` can be chained together multiple times, as\neach returns a reference. The exception is the `parent` of `root`, which\nis `null`. \n\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\nconst storage = getStorage();\nconst spaceRef = ref(storage, 'images/space.jpg');\n\n// References can be chained together multiple times\nconst earthRef = ref(spaceRef.parent, 'earth.jpg');\n// earthRef points to 'images/earth.jpg'\n\n// nullRef is null, since the parent of root is null\nconst nullRef = spaceRef.root.parent;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_navigate_ref_chain.js#L8-L18\n```\n\nWeb \n\n```javascript\n// References can be chained together multiple times\nvar earthRef = spaceRef.parent.child('earth.jpg');\n// earthRef points to 'images/earth.jpg'\n\n// nullRef is null, since the parent of root is null\nvar nullRef = spaceRef.root.parent;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L47-L52\n```\n\nReference Properties\n\nYou can inspect references to better understand the files they point to\nusing the `fullPath`, `name`, and `bucket` properties. These properties\nget the full path of the file, the name of the file,\nand the bucket the file is stored in. \n\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\nconst storage = getStorage();\nconst spaceRef = ref(storage, 'images/space.jpg');\n\n// Reference's path is: 'images/space.jpg'\n// This is analogous to a file path on disk\nspaceRef.fullPath;\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 where files are stored\nspaceRef.bucket;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_ref_properties.js#L8-L22\n```\n\nWeb \n\n```javascript\n// Reference's path is: 'images/space.jpg'\n// This is analogous to a file path on disk\nspaceRef.fullPath;\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 where files are stored\nspaceRef.bucket;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L60-L69\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\nWeb \n\n```javascript\nimport { getStorage, ref } from \"firebase/storage\";\n\nconst storage = getStorage();\n\n// Points to the root reference\nconst storageRef = ref(storage);\n\n// Points to 'images'\nconst imagesRef = ref(storageRef, 'images');\n\n// Points to 'images/space.jpg'\n// Note that you can use variables to create child values\nconst fileName = 'space.jpg';\nconst spaceRef = ref(imagesRef, fileName);\n\n// File path is 'images/space.jpg'\nconst path = spaceRef.fullPath;\n\n// File name is 'space.jpg'\nconst name = spaceRef.name;\n\n// Points to 'images'\nconst imagesRefAgain = spaceRef.parent;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/snippets/storage-next/create-reference/storage_ref_full_example.js#L8-L30\n```\n\nWeb \n\n```javascript\n// Points to the root reference\nvar storageRef = firebase.storage().ref();\n\n// Points to 'images'\nvar imagesRef = storageRef.child('images');\n\n// Points to 'images/space.jpg'\n// Note that you can use variables to create child values\nvar fileName = 'space.jpg';\nvar spaceRef = imagesRef.child(fileName);\n\n// File path is 'images/space.jpg'\nvar path = spaceRef.fullPath;\n\n// File name is 'space.jpg'\nvar name = spaceRef.name;\n\n// Points to 'images'\nvar imagesRef = spaceRef.parent;https://github.com/firebase/snippets-web/blob/467eaa165dcbd9b3ab15711e76fa52237ba37f8b/storage/create-reference.js#L75-L93\n```\n\nNext, let's learn how to\n[upload files](/docs/storage/web/upload-files) to\nCloud Storage."]]