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) Dropbox File Streaming UploadUpload a file to Drobox using a file stream. This example can upload files up to 150MB. Larger files must be uploaded with an upload session (upload_session/start).
' 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("Content-Type","application/octet-stream") success = rest.AddHeader("Authorization","Bearer DROPBOX_ACCESS_TOKEN") ' The upload "parameters" contained in JSON passed in an HTTP request header. ' This is the JSON to be added in this example: ' { ' "path": "/Homework/lit/hamlet.xml", ' "mode": "add", ' "autorename": true, ' "mute": false ' } Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.AppendString("path","/Homework/lit/hamlet.xml") success = json.AppendString("mode","add") success = json.AppendBool("autorename",True) success = json.AppendBool("mute",False) success = rest.AddHeader("Dropbox-API-Arg",json.Emit()) ' Almost ready to go... ' Let's setup a file stream to point to a file. Dim fileStream As Chilkat.Stream Set fileStream = Chilkat.NewStream fileStream.SourceFile = "qa_data/xml/hamlet.xml" ' Do the upload. The URL is https://content.dropboxapi.com/2/files/upload. ' We already connected to content.dropboxapi.com using TLS (i.e. HTTPS), ' so now we only need to specify the path "/2/files/upload". ' Note: The file is streamed directly from disk. (The entire ' file will not be loaded into memory.) responseStr = rest.FullRequestStream("POST","/2/files/upload",fileStream) 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): "; responseStr Debug.Print "---" Debug.Print "LastRequestStartLine: "; rest.LastRequestStartLine Debug.Print "LastRequestHeader: "; rest.LastRequestHeader Exit Sub End If ' The response is JSON. Dim jsonResp As Chilkat.JsonObject Set jsonResp = Chilkat.NewJsonObject jsonResp.EmitCompact = False success = jsonResp.Load(responseStr) ' Show the JSON response. Debug.Print jsonResp.Emit() ' Returns JSON that looks like this: ' { ' "name": "hamlet.xml", ' "path_lower": "/homework/lit/hamlet.xml", ' "path_display": "/Homework/lit/hamlet.xml", ' "id": "id:74FkdeNuyKAAAAAAAAAAAQ", ' "client_modified": "2016-06-02T23:19:00Z", ' "server_modified": "2016-06-02T23:19:00Z", ' "rev": "9482db15f", ' "size": 279658 ' } ' Sample code to get data from the JSON response: size = jsonResp.IntOf("size") Debug.Print "size = "; size rev = jsonResp.StringOf("rev") Debug.Print "rev = "; rev clientModified = jsonResp.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.