Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Upload String to DropboxUploads a string to a file on Dropbox. This example can upload content up to 150MB, assuming a 150MB string fits in memory for your app. Larger files must be uploaded with an upload session (upload_session/start).
load ./chilkat.dll # 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. set rest [new_CkRest] # Connect to Dropbox set success [CkRest_Connect $rest "content.dropboxapi.com" 443 1 1] if {$success != 1} then { puts [CkRest_lastErrorText $rest] delete_CkRest $rest exit } # Add request headers. CkRest_AddHeader $rest "Content-Type" "application/octet-stream" CkRest_AddHeader $rest "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": "/jack.txt", # "mode": "add", # "autorename": true, # "mute": false # } # This will be the content of the file created in Dropbox. set content "All work and no play makes Jack a dull boy" set json [new_CkJsonObject] CkJsonObject_AppendString $json "path" "/jack.txt" CkJsonObject_AppendString $json "mode" "add" CkJsonObject_AppendBool $json "autorename" 1 CkJsonObject_AppendBool $json "mute" 0 CkRest_AddHeader $rest "Dropbox-API-Arg" [CkJsonObject_emit $json] # 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". set responseStr [CkRest_fullRequestString $rest "POST" "/2/files/upload" $content] if {[CkRest_get_LastMethodSuccess $rest] != 1} then { puts [CkRest_lastErrorText $rest] delete_CkRest $rest delete_CkJsonObject $json exit } # When successful, Dropbox responds with a 200 response code. if {[CkRest_get_ResponseStatusCode $rest] != 200} then { # Examine the request/response to see what happened. puts "response status code = [CkRest_get_ResponseStatusCode $rest]" puts "response status text = [CkRest_responseStatusText $rest]" puts "response header: [CkRest_responseHeader $rest]" puts "response body (if any): $responseStr" puts "---" puts "LastRequestStartLine: [CkRest_lastRequestStartLine $rest]" puts "LastRequestHeader: [CkRest_lastRequestHeader $rest]" delete_CkRest $rest delete_CkJsonObject $json exit } puts "LastRequestHeader: [CkRest_lastRequestHeader $rest]" # The response is JSON. set jsonResp [new_CkJsonObject] CkJsonObject_put_EmitCompact $jsonResp 0 CkJsonObject_Load $jsonResp $responseStr # Show the JSON response. puts [CkJsonObject_emit $jsonResp] # Returns JSON that 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 # } # Sample code to get data from the JSON response: set size [CkJsonObject_IntOf $jsonResp "size"] puts "size = $size" set rev [CkJsonObject_stringOf $jsonResp "rev"] puts "rev = $rev" set clientModified [CkJsonObject_stringOf $jsonResp "client_modified"] set ckdt [new_CkDateTime] CkDateTime_SetFromTimestamp $ckdt $clientModified set bLocalTime 1 # dt is a CkDtObj set dt [CkDateTime_GetDtObj $ckdt $bLocalTime] puts [CkDtObj_get_Day $dt]/[CkDtObj_get_Month $dt]/[CkDtObj_get_Year $dt] [CkDtObj_get_Hour $dt]:[CkDtObj_get_Minute $dt] delete_CkDtObj $dt delete_CkRest $rest delete_CkJsonObject $json delete_CkJsonObject $jsonResp delete_CkDateTime $ckdt |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.