Google is committed to advancing racial equity for Black communities. See how.
Ta strona została przetłumaczona przez Cloud Translation API.
Switch to English

Utwórz odniesienie do magazynu w sieci Web

Twoje pliki są przechowywane w zasobniku Google Cloud Storage . Pliki w tym zasobniku są przedstawiane w strukturze hierarchicznej, podobnie jak system plików na lokalnym dysku twardym lub dane w bazie danych czasu rzeczywistego Firebase. Tworząc odniesienie do pliku, aplikacja uzyskuje do niego dostęp. Te odniesienia można następnie wykorzystać do przesyłania lub pobierania danych, pobierania lub aktualizowania metadanych lub usuwania pliku. Odwołanie może wskazywać określony plik lub węzeł wyższego poziomu w hierarchii.

Jeśli korzystałeś z Bazy danych czasu rzeczywistego Firebase , te ścieżki mogą wydawać się Ci bardzo znajome - a powinny! Jednak dane plików są przechowywane w Google Cloud Storage, a nie w bazie danych czasu rzeczywistego.

Utwórz odniesienie

Aby załadować lub pobrać pliki, usunąć pliki lub pobrać lub zaktualizować metadane, musisz utworzyć odniesienie do pliku, na którym chcesz operować. Odniesienie można traktować jako wskaźnik do pliku w chmurze. Referencje są lekkie, więc możesz utworzyć tyle, ile potrzebujesz, a także można ich ponownie używać w wielu operacjach.

Utwórz odniesienia z usługi storage() w aplikacji Firebase. To odniesienie wskazuje na katalog główny Twojego zasobnika Cloud Storage.

// 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();

Możesz utworzyć odniesienie do lokalizacji niżej w drzewie, na przykład 'images/space.jpg' , używając metody child() na istniejącym odwołaniu.

// 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"

Możesz również użyć właściwości parent i root , aby nawigować w górę hierarchii plików. parent przechodzi o jeden poziom wyżej, podczas gdy root przechodzi do samego szczytu.

// 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 i root mogą być połączone ze sobą wiele razy, ponieważ każdy zwraca odwołanie. Wyjątkiem jest parent root , który ma null .

// 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;

Właściwości odniesienia

Można sprawdzić referencje, aby lepiej zrozumieć pliki oni wskazują na użyciu fullPath , name i bucket właściwości. Te właściwości pobierają pełną ścieżkę do pliku, nazwę pliku i zasobnik, w którym plik jest przechowywany.

// 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;

Ograniczenia odniesień

Ścieżki i nazwy referencyjne mogą zawierać dowolną sekwencję prawidłowych znaków Unicode, ale nakładane są pewne ograniczenia, w tym:

  1. Całkowita długość reference.fullPath musi wynosić od 1 do 1024 bajtów, gdy kodowane jest w UTF-8.
  2. Brak znaków powrotu karetki lub nowego wiersza.
  3. Unikaj używania # , [ , ] , * lub ? , ponieważ nie działają one dobrze z innymi narzędziami, takimi jak Baza danych czasu rzeczywistego Firebase lub gsutil .

Pełny przykład

// 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;

Następnie dowiedzmy się, jak przesyłać pliki do Cloud Storage.