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 |
|
||||
Exportar acciones |
|
Antes de descargar o exportar el contenido de un archivo, verifica que los usuarios puedan descargarlo con el campo capabilities.canDownload
del recurso files
.
Para obtener descripciones de los tipos de archivos que se mencionan aquí, incluidos los archivos blob y de 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.
Descarga el contenido del archivo BLOB
Para descargar un archivo BLOB almacenado en Drive, usa el método files.get
con el ID del archivo que se descargará 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.
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 es necesario que establezcas este parámetro de forma explícita.
En el siguiente ejemplo 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 este ejemplo 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 autorizarse con un alcance que permita el acceso de lectura al contenido del archivo. Por ejemplo, una app que usa el alcance de drive.readonly.metadata
no está autorizada para descargar el contenido del archivo.
En este ejemplo de código, se usa el alcance de archivo "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.
Los usuarios con permisos de owner
(para los archivos de Mi unidad) o organizer
(para los archivos de unidades compartidas) pueden restringir la descarga a través del objeto DownloadRestrictionsMetadata
. Para obtener más información, consulta Cómo evitar que los usuarios descarguen, impriman o copien tu archivo.
Solo el propietario del archivo 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 reconoce el riesgo de descargar software potencialmente no deseado o archivos abusivos. 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
Descarga el contenido del archivo blob en una versión anterior
Solo puedes descargar las revisiones de contenido de archivos BLOB que estén marcadas como "Conservar para siempre". Si quieres descargar una revisión, primero configúrala como "Conservar para siempre". Para obtener más información, consulta Cómo especificar las revisiones que se guardarán del borrado automático.
Para descargar el contenido de los archivos de 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, consulta Administra operaciones de larga duración.
Aquí se muestra el protocolo de la solicitud.
GET https://www.googleapis.com/drive/v3/files/{FILE_ID
}/revisions/{REVISION_ID
}?alt=media
Descarga el contenido del archivo blob en un navegador
Para descargar el contenido de los archivos BLOB almacenados en Drive dentro de 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 devuelve un vínculo para descargar el archivo 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 del archivo 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 se descargará. De forma opcional, puedes establecer el ID de la revisión. Esta es la única forma de descargar archivos de Google Vids. Para obtener más información, consulta Administra operaciones de larga duración.
Exporta 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 se exportará y el tipo de MIME correcto. El contenido exportado se limita a 10 MB.
En el siguiente ejemplo 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
Esta muestra de código usa el alcance 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.
El código de muestra 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 admitidos para cada documento de Google Workspace, consulta Tipos de MIME de exportación para documentos de Google Workspace.
Cómo exportar contenido de documentos de Google Workspace en un navegador
Para exportar contenido de documentos de Google Workspace en un navegador, usa el campo exportLinks
del recurso files
. Según el tipo de documento, se devuelve 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 ofrecerla como un vínculo en el que se puede hacer clic.
Cómo exportar contenido de documentos de Google Workspace en una versión anterior en un navegador
Para exportar el contenido de un documento de Google Workspace en una versión anterior dentro de un navegador, usa el método revisions.get
con el ID del archivo que se descargará y el ID de la revisión para generar un vínculo de exportación desde el que puedas realizar la descarga. Si el usuario tiene acceso de descarga al archivo, se muestra un vínculo para descargar el archivo 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 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.
Limita la forma en que se comparten los archivos
- Protege el contenido de los archivos
- Tipos de MIME de exportación para documentos de Google Workspace