Google Drive API 支援多種下載和匯出操作,如下表所示:
下載內容 |
|
|||
匯出項目 |
|
本指南的其餘部分將詳細說明如何執行這類類型的下載和匯出作業。
下載 blob 檔案內容
如要下載儲存在雲端硬碟中的 blob 檔案,請使用 files.get
方法搭配要下載的檔案 ID 和 alt=media
網址參數。alt=media
網址參數會指示伺服器要求下載的內容做為替代回應格式。
alt=media
網址參數是一種系統參數,適用於所有 Google REST API。如果您使用 Drive API 的用戶端程式庫,就不需要明確設定這個參數,
以下程式碼範例說明如何使用 files.get
方法透過 Drive API 用戶端程式庫下載檔案。
Java
Python
Node.js
PHP
.NET
這個程式碼範例會使用程式庫方法,將 alt=media
網址參數加入基礎 HTTP 要求中。
從應用程式啟動的檔案下載作業必須獲得允許存取檔案內容的範圍。舉例來說,使用 drive.readonly.metadata
範圍的應用程式無權下載檔案內容。這個程式碼範例使用受限制的「雲端硬碟」檔案範圍,可讓使用者查看及管理所有的雲端硬碟檔案。如要進一步瞭解雲端硬碟範圍,請參閱 API 專屬授權與驗證資訊。
具有編輯權限的使用者可以將 copyRequiresWriterPermission
欄位設為 false
,以唯讀方式限制下載作業。
標示為濫用 (例如有害軟體) 的檔案僅供檔案擁有者下載。此外,您必須加入 get
查詢參數 acknowledgeAbuse=true
,表示使用者已確認下載潛在垃圾軟體或其他濫用檔案。您的應用程式應先互動使用者,再使用這個查詢參數。
部分下載
下載部分只下載該檔案的特定部分。您可以使用含有 Range
標頭的位元組範圍,指定要下載的檔案部分。例如:
Range: bytes=500-999
下載舊版 blob 檔案內容
如要下載舊版 blob 檔案的內容,請將 revisions.get
方法與要下載的檔案 ID、修訂版本 ID 和 alt=media
網址參數搭配使用。alt=media
網址參數會指示伺服器下載要求的內容做為替代回應格式。與 files.get
類似,revisions.get
方法也接受選用的查詢參數 acknowledgeAbuse
和 Range
標頭。如要進一步瞭解如何下載修訂版本,請參閱「下載並發布檔案修訂版本」。
在瀏覽器中下載 blob 檔案內容
如要下載儲存在雲端硬碟中的 blob 檔案內容,而非透過 API,請使用 Files
資源的 webContentLink
欄位。如果使用者俱有該檔案的下載權限,系統會傳回下載連結及其內容。您可以將使用者重新導向至這個網址,或提供可點擊的連結。
匯出 Google Workspace 文件內容
如要匯出 Google Workspace 文件位元組內容,請使用 files.export
方法搭配要匯出的檔案 ID 和正確的 MIME 類型。匯出內容的大小上限為 10 MB。
以下程式碼範例示範如何使用 files.export
方法,透過 Drive API 用戶端程式庫將 Google Workspace 文件匯出為 PDF 文件:
Java
Python
Node.js
PHP
.NET
這個程式碼範例使用受限制的 drive
範圍,可讓使用者查看及管理您所有的雲端硬碟檔案。如要進一步瞭解雲端硬碟範圍,請參閱 API 專屬授權與驗證資訊。
程式碼範例也會將匯出 MIME 類型宣告為 application/pdf
。如需 Google Workspace 文件支援的所有匯出 MIME 類型完整清單,請參閱匯出 Google Workspace 文件的 MIME 類型。
在瀏覽器中匯出 Google Workspace 文件內容
如要在瀏覽器中匯出 Google Workspace 文件內容,請使用 Files
資源的 exportLinks
欄位。系統會根據文件類型提供檔案連結及其內容,並針對每個可用的 MIME 類型傳回內容。您可以將使用者重新導向至網址,或提供可點擊的連結。
在瀏覽器中匯出舊版本的 Google Workspace 文件內容
如要在瀏覽器中匯出舊版本的 Google Workspace 文件內容,請使用 revisions.get
方法搭配要下載的檔案 ID 和修訂版本 ID。如果使用者俱有該檔案的下載存取權,系統會傳回下載連結及其內容。您可以將使用者重新導向至這個網址,或提供可點擊的連結。