Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Download GMail Message Attachment by IDDemonstrates how to download a GMail email attachment by the attachment ID. For more information, see https://developers.google.com/gmail/api/v1/reference/users/messages/attachments/get
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim http As Chilkat.Http Set http = Chilkat.NewHttp http.AuthToken = "ACCESS_TOKEN" http.Accept = "application/json" ' See the following example: Get GMail Message (format=full) ' It shows how to download an email by message ID, and it shows how to parse the JSON ' response which includes attachment names, ids, and other information. ' This example will assume we already have the attachment id and filename. ' This is the attachment ID for a file named "helloWorld.pdf". attachmentId = "ANGjdJ-oy3aCuZISJKLAhUdaEksCEklbAPyMaWzFgqOMGbPCRkgwgeu_Kttd99C17OBTHROkDZGekibTKWXGfscB5ww7fw4E65_V1dQ-jHhb2TD1Cdm58-BbNw2iDxzptco8iILPiSnLLfFn5Ps7nsRcxHaGTt3r0yqFKCuIYNnPK1vM04BXI_cfzo-HnI4I3tD6oHNHOGVQrL01MdShFQjPELPUjXM8z1qs7Kom-QyvV1iOldUN-66UuhynsmDX-CMM5TIdB-8KD_lmdhf-0DqG8JnCA20XpXyfqwS8XFkPA-t-QSjb7SdkHQFtQ4lz2PcBREFzZ2eI5j0l0Y_dQHRPYTeMwkVl1yl4MfFT4C4iso3VSF-eqaIjiFCbXKCFNyeEIW5WFsv189dhlSqU" messageId = "1712bc1dc22da2a2" Dim success As Boolean success = http.SetUrlVar("messageId",messageId) success = http.SetUrlVar("attachmentId",attachmentId) url = "https://www.googleapis.com/gmail/v1/users/userId/messages/{$messageId}/attachments/{$attachmentId}" ' When we download, the response is JSON that contains the attachment data base64url encoded, like this: ' { ' "size": 934, ' "data": "JVBERi0xLjM ... CiUlRU9GCg==" ' } outputFilePath = "qa_output/helloWorld.pdf" ' Download into a StringBuilder. Dim sbJson As Chilkat.StringBuilder Set sbJson = Chilkat.NewStringBuilder success = http.DownloadSb(url,"utf-8",sbJson) If (success = False) Then Debug.Print http.LastErrorText Exit Sub End If If (http.LastStatus <> 200) Then ' Something failed. ' the JSON contains an error message. Debug.Print sbJson.GetAsString() Exit Sub End If ' Load into a Chilkat JSON object. Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.LoadSb(sbJson) ' Extract the base64url data into a BinData. Dim bd As Chilkat.BinData Set bd = Chilkat.NewBinData success = json.BytesOf("data","base64url",bd) ' Save the data to a file. success = bd.WriteFile("qa_output/helloWorld.pdf") Debug.Print "Success." |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.