Crea una referencia de Cloud Storage en Flutter

Sus archivos se almacenan en un depósito de Cloud Storage . Los archivos en este depósito se presentan en una estructura jerárquica, al igual que el sistema de archivos en su disco duro local o los datos en Firebase Realtime Database. Al crear una referencia a un archivo, su aplicación obtiene acceso a él. Estas referencias se pueden usar 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 pensar en una referencia como un puntero a un archivo en la nube. Las referencias son ligeras, por lo que puede crear tantas como necesite. También son reutilizables para múltiples operaciones.

Crea una referencia usando la instancia singleton de FirebaseStorage y llamando a su método ref() .

final storageRef = FirebaseStorage.instance.ref();

A continuación, puede crear una referencia a una ubicación más baja en el árbol, digamos "images/space.jpg" usando 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 usar las propiedades parent y root para navegar hacia arriba en nuestra jerarquía de archivos. parent sube un nivel, mientras que root navega hasta el final.

// 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 a root.parent da 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 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 en las Referencias

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

  1. La longitud total de reference.fullPath debe estar entre 1 y 1024 bytes cuando se codifica en UTF-8.
  2. Sin caracteres de retorno de carro o avance de línea.
  3. Evite usar # , [ , ] , * 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.