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 File from Dropbox into a String VariableDemonstrates how to download a file from Dropbox directly into a string variable.
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' A Dropbox access token should have been previously obtained. ' Dropbox access tokens do not expire. ' See Dropbox Access Token. Dim rest As Chilkat.Rest Set rest = Chilkat.NewRest ' Connect to Dropbox success = rest.Connect("content.dropboxapi.com",443,True,True) If (success <> True) Then Debug.Print rest.LastErrorText Exit Sub End If ' Add request headers. Dim success As Boolean success = rest.AddHeader("Authorization","Bearer DROPBOX_ACCESS_TOKEN") ' The download "parameters" are contained in JSON passed in an HTTP request header. ' This is the JSON indicating the file to be downloaded: ' { ' "path": "/jack.txt", ' } Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.AppendString("path","/jack.txt") success = rest.AddHeader("Dropbox-API-Arg",json.Emit()) ' The content of the file on Dropbox is returned. fileContent = rest.FullRequestNoBody("POST","/2/files/download") If (rest.LastMethodSuccess <> True) Then Debug.Print rest.LastErrorText Exit Sub End If ' When successful, Dropbox responds with a 200 response code. If (rest.ResponseStatusCode <> 200) Then ' Examine the request/response to see what happened. Debug.Print "response status code = "; rest.ResponseStatusCode Debug.Print "response status text = "; rest.ResponseStatusText Debug.Print "response header: "; rest.ResponseHeader Debug.Print "response body (if any): "; fileContent Debug.Print "---" Debug.Print "LastRequestStartLine: "; rest.LastRequestStartLine Debug.Print "LastRequestHeader: "; rest.LastRequestHeader Exit Sub End If ' Show the file content that was downloaded: Debug.Print fileContent Debug.Print "----" ' Information about the downloaded file is also available as JSON in a response header. ' The "dropbox-api-result" response header contains the information. For example: apiResult = rest.ResponseHdrByName("dropbox-api-result") Debug.Print apiResult ' In this case, the pretty-formatted dropbox-api-result JSON looks like this: ' { ' "name": "jack.txt", ' "path_lower": "/jack.txt", ' "path_display": "/jack.txt", ' "id": "id:yqx4-tE_NKAAAAAAAAAAAQ", ' "client_modified": "2016-06-02T20:42:11Z", ' "server_modified": "2016-06-02T20:42:11Z", ' "rev": "8482db15f", ' "size": 42 ' } ' Load the JSON, pretty-print it, and demonstrate how to get some values... Dim jsonResult As Chilkat.JsonObject Set jsonResult = Chilkat.NewJsonObject jsonResult.EmitCompact = False success = jsonResult.Load(apiResult) ' Show the JSON pretty-printed... Debug.Print jsonResult.Emit() ' Sample code to get data from the JSON response: size = jsonResult.IntOf("size") Debug.Print "size = "; size rev = jsonResult.StringOf("rev") Debug.Print "rev = "; rev clientModified = jsonResult.StringOf("client_modified") Dim ckdt As Chilkat.CkDateTime Set ckdt = Chilkat.NewCkDateTime success = ckdt.SetFromTimestamp(clientModified) bLocalTime = True Set dt = ckdt.GetDtObj(bLocalTime) Debug.Print dt.Day; "/"; dt.Month; "/"; dt.Year; " "; dt.Hour; ":"; dt.Minute |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.