Crea una referencia de Cloud Storage en Flutter

Sus archivos se almacenan en un depósito de Cloud Storage . Los archivos de este depósito se presentan en una estructura jerárquica, al igual que el sistema de archivos de su disco duro local o los datos de Firebase Realtime Database. Al crear una referencia a un archivo, su aplicación obtiene acceso a él. Estas referencias se pueden utilizar para cargar o descargar datos, obtener o actualizar metadatos o eliminar el archivo. Una referencia puede apuntar a un archivo específico o a un nodo de nivel superior en la jerarquía.

Si ha utilizado Firebase Realtime Database , estas rutas le resultarán muy familiares. Sin embargo, los datos de su archivo se almacenan en Cloud Storage, no en Realtime Database.

Crear una referencia

Cree una referencia para cargar, descargar o eliminar un archivo, o para obtener o actualizar sus metadatos. Se puede considerar una referencia como un puntero a un archivo en la nube. Las referencias son livianas, por lo que puedes crear tantas como necesites. También son reutilizables para múltiples operaciones.

Cree una referencia utilizando la instancia singleton FirebaseStorage y llamando a su método ref() .

final storageRef = FirebaseStorage.instance.ref();

A continuación, puede crear una referencia a una ubicación inferior en el árbol, digamos "images/space.jpg" utilizando el método child() en una referencia existente.

// Create a child reference
// imagesRef now points to "images"
final imagesRef = storageRef.child("images");

// Child references can also take paths
// spaceRef now points to "images/space.jpg
// imagesRef still points to "images"
final spaceRef = storageRef.child("images/space.jpg");

También puede utilizar las propiedades parent y root para navegar hacia arriba en nuestra jerarquía de archivos. parent navega hacia arriba un nivel, mientras que root navega hasta la cima.

// parent allows us to move our reference to a parent node
// imagesRef2 now points to 'images'
final imagesRef2 = spaceRef.parent;

// root allows us to move all the way back to the top of our bucket
// rootRef now points to the root
final rootRef = spaceRef.root;

child() , parent y root se pueden encadenar varias veces, ya que cada uno es una referencia. Pero acceder root.parent como resultado null .

// References can be chained together multiple times
// earthRef points to 'images/earth.jpg'
final earthRef = spaceRef.parent?.child("earth.jpg");

// nullRef is null, since the parent of root is null
final nullRef = spaceRef.root.parent;

Propiedades de referencia

Puede inspeccionar las referencias para comprender mejor los archivos a los que apuntan utilizando las propiedades fullPath , name y bucket . Estas propiedades obtienen la ruta completa, el nombre y el depósito del archivo.

// 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 that the files are stored in
spaceRef.bucket;

Limitaciones de referencias

Las rutas de referencia y los nombres pueden contener cualquier secuencia de caracteres Unicode válidos, pero se imponen ciertas restricciones, entre ellas:

  1. La longitud total de reference.fullPath debe estar entre 1 y 1024 bytes cuando está codificado en UTF-8.
  2. Sin caracteres de retorno de carro ni salto de línea.
  3. Evite el uso de # , [ , ] , * o ? , ya que no funcionan bien con otras herramientas como Firebase Realtime Database o gsutil .

Ejemplo completo

// Points to the root reference
final storageRef = FirebaseStorage.instance.ref();

// Points to "images"
Reference? imagesRef = storageRef.child("images");

// Points to "images/space.jpg"
// Note that you can use variables to create child values
final fileName = "space.jpg";
final spaceRef = imagesRef.child(fileName);

// File path is "images/space.jpg"
final path = spaceRef.fullPath;

// File name is "space.jpg"
final name = spaceRef.name;

// Points to "images"
imagesRef = spaceRef.parent;

A continuación, aprendamos cómo cargar archivos en Cloud Storage.