La API de Google Drive admite varios tipos de acciones de descarga y exportación, como se indica en la siguiente tabla:
Acciones de descarga |
|
||||
Acciones de exportación |
|
Antes de descargar o exportar el contenido de un archivo, verifica que los usuarios puedan descargarlo con el campo capabilities.canDownload
en el recurso files
.
Para obtener descripciones de los tipos de archivos que se mencionan aquí, incluidos los archivos de blob y Google Workspace, consulta Tipos de archivos.
En el resto de esta guía, se proporcionan instrucciones detalladas para realizar estos tipos de acciones de descarga y exportación.
Cómo descargar el contenido de un archivo BLOB
Para descargar un archivo blob almacenado en Drive, usa el método files.get
con el ID del archivo que deseas descargar y el parámetro de URL alt=media
. El parámetro de URL alt=media
le indica al servidor que se está solicitando una descarga de contenido como formato de respuesta alternativo.
El parámetro de URL alt=media
es un parámetro del sistema disponible en todas las APIs de REST de Google. Si usas una biblioteca cliente para la API de Drive, no necesitas configurar este parámetro de forma explícita.
En la siguiente muestra de código, se muestra cómo usar el método files.get
para descargar un archivo con las bibliotecas cliente de la API de Drive.
Java
Python
Node.js
PHP
.NET
En esta muestra de código, se usa un método de biblioteca que agrega el parámetro de URL alt=media
a la solicitud HTTP subyacente.
Las descargas de archivos que se inician desde tu app deben estar autorizadas con un permiso que permita el acceso de lectura al contenido del archivo. Por ejemplo, una app que usa el permiso drive.readonly.metadata
no está autorizada para descargar el contenido del archivo.
En esta muestra de código, se usa el permiso de archivo restringido "drive" que permite a los usuarios ver y administrar todos tus archivos de Drive. Para obtener más información sobre los permisos de Drive, consulta Elige permisos para la API de Google Drive.
Los usuarios con permisos de edición pueden restringir la descarga de los usuarios de solo lectura configurando el campo copyRequiresWriterPermission
en false
.
Solo el propietario puede descargar los archivos identificados como abusivos (como software dañino).
Además, se debe incluir el parámetro de consulta get
acknowledgeAbuse=true
para indicar que el usuario reconoció el riesgo de descargar software potencialmente no deseado o algún otro archivo abusivo. Tu aplicación debe advertir al usuario de forma interactiva antes de usar este parámetro de consulta.
Descarga parcial
La descarga parcial implica descargar solo una parte especificada de un archivo. Puedes
especificar la parte del archivo que deseas descargar con un rango de bytes con el
encabezado Range
. Por ejemplo:
Range: bytes=500-999
Cómo descargar el contenido de un archivo blob en una versión anterior
Para descargar el contenido de los archivos blob en una versión anterior, usa el método revisions.get
con el ID del archivo que se descargará, el ID de la revisión y el parámetro de URL alt=media
.
El parámetro de URL alt=media
le indica al servidor que se solicita una descarga de contenido como formato de respuesta alternativo. Al igual que files.get
, el método revisions.get
también acepta el parámetro de consulta opcional acknowledgeAbuse
y el encabezado Range
. Para obtener más información sobre cómo descargar revisiones, consulta Administra las revisiones de archivos.
Aquí se muestra el protocolo de solicitud.
GET https://www.googleapis.com/drive/v3/files/{FILE_ID
}/revisions/{REVISION_ID
}?alt=media
Descarga el contenido de un archivo blob en un navegador
Para descargar el contenido de los archivos BLOB almacenados en Drive desde un navegador, en lugar de hacerlo a través de la API, usa el campo webContentLink
del recurso files
. Si el usuario tiene acceso de descarga al archivo, se muestra un vínculo para descargarlo y su contenido. Puedes redireccionar a un usuario a esta URL o ofrecerla como un vínculo en el que se puede hacer clic.
Descarga el contenido de los archivos BLOB durante las operaciones de larga duración
Para descargar el contenido de los archivos de blob durante las operaciones de larga duración, usa el método files.download
con el ID del archivo que deseas descargar. De forma opcional, puedes establecer el ID de la revisión. Esta es la única manera de descargar archivos de Google Vids. Para obtener más información, consulta Administra operaciones de larga duración.
Cómo exportar el contenido de documentos de Google Workspace
Para exportar el contenido de bytes de un documento de Google Workspace, usa el método files.export
con el ID del archivo que deseas exportar y el tipo de MIME correcto. El contenido exportado se limita a 10 MB.
En la siguiente muestra de código, se muestra cómo usar el método files.export
para exportar un documento de Google Workspace en formato PDF con las bibliotecas cliente de la API de Drive:
Java
Python
Node.js
PHP
.NET
En esta muestra de código, se usa el alcance drive
restringido que permite a los usuarios ver y administrar todos tus archivos de Drive. Para obtener más información sobre los permisos de Drive, consulta Elige permisos para la API de Google Drive.
La muestra de código también declara el tipo de MIME de exportación como application/pdf
. Para obtener una lista completa de todos los tipos de MIME de exportación compatibles con cada documento de Google Workspace, consulta Tipos de MIME de exportación para documentos de Google Workspace.
Cómo exportar el contenido de un documento de Google Workspace en un navegador
Para exportar el contenido de un documento de Google Workspace en un navegador, usa el campo exportLinks
del recurso files
. Según el tipo de archivo, se muestra un vínculo para descargar el archivo y su contenido para cada tipo de MIME disponible. Puedes redireccionar a un usuario a una URL o ofrecérsela como un
vínculo en el que se puede hacer clic.
Cómo exportar el contenido de un documento de Google Workspace a una versión anterior en un navegador
Para exportar el contenido de un documento de Google Workspace a una versión anterior en un navegador, usa el método revisions.get
con el ID del archivo que quieres descargar y el ID de la revisión para generar un vínculo de exportación desde el que puedes realizar la descarga. Si el usuario tiene acceso de descarga al archivo, se muestra un vínculo para descargarlo y su contenido. Puedes redireccionar a un usuario a esta URL o ofrecerla como un vínculo en el que se puede hacer clic.
Exporta el contenido de documentos de Google Workspace durante operaciones de larga duración
Para exportar el contenido de documentos de Google Workspace durante operaciones de larga duración, usa el método files.download
con el ID del archivo que se descargará y el ID de la revisión. Para obtener más información, consulta Administra operaciones de larga duración.