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) S3 Upload String using AWS Signature Version 2Example to upload the contents of a string to the Amazon S3 service, using the older AWS Signature Version 2.
load ./chilkat.dll # Demonstrates how to use older AWS S3 Signature Version 2 for uploading the contents # of a string variable to an object in a bucket. # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set rest [new_CkRest] # Connect to the Amazon AWS REST server. set bTls 1 set port 443 set bAutoReconnect 1 # The file is uploaded to the bucket named "chilkat100", which becomes part of the domain: set success [CkRest_Connect $rest "chilkat100.s3.amazonaws.com" $port $bTls $bAutoReconnect] # ---------------------------------------------------------------------------- # Important: For buckets created in regions outside us-east-1, # there are three important changes that need to be made. # See Working with S3 Buckets in Non-us-east-1 Regions for the details. # ---------------------------------------------------------------------------- # Provide AWS credentials for the REST call. set authAws [new_CkAuthAws] CkAuthAws_put_AccessKey $authAws "AWS_ACCESS_KEY" CkAuthAws_put_SecretKey $authAws "AWS_SECRET_KEY" CkAuthAws_put_ServiceName $authAws "s3" # For AWS Signature Version 2, the following two properties need to be set: CkAuthAws_put_SignatureVersion $authAws 2 # See http://docs.aws.amazon.com/AmazonS3/latest/dev/RESTAuthentication.html#ConstructingTheCanonicalizedResourceElement # The bucket is "chilkat100", and the uriPath is "/hamlet_play.xml", which must match # the URI path passed to the FullRequestString method below. CkAuthAws_put_CanonicalizedResourceV2 $authAws "/chilkat100/hamlet_play.xml" set success [CkRest_SetAuthAws $rest $authAws] # Load a text file into memory. set fac [new_CkFileAccess] set fileContents [CkFileAccess_readEntireTextFile $fac "qa_data/xml/hamlet.xml" "utf-8"] if {[CkFileAccess_get_LastMethodSuccess $fac] != 1} then { puts [CkFileAccess_lastErrorText $fac] delete_CkRest $rest delete_CkAuthAws $authAws delete_CkFileAccess $fac exit } # To send the file in gzip or deflate compressed format, set the Content-Encoding request # header to "gzip" or "deflate". (this is optional) set success [CkRest_AddHeader $rest "Content-Encoding" "gzip"] # Indicate the Content-Type of our upload. (This is optional) set success [CkRest_AddHeader $rest "Content-Type" "text/xml"] # We can add an "Expect: 100-continue" header so that if the request is rejected # by the server immediately after receiving the request header, it can respond # and the client (Chilkat) can avoid sending the file data. # (this is optional) set success [CkRest_AddHeader $rest "Expect" "100-continue"] # Upload the file to Amazon S3. set responseBodyStr [CkRest_fullRequestString $rest "PUT" "/hamlet_play.xml" $fileContents] if {[CkRest_get_LastMethodSuccess $rest] != 1} then { puts [CkRest_lastErrorText $rest] delete_CkRest $rest delete_CkAuthAws $authAws delete_CkFileAccess $fac exit } # Did we get a 200 response indicating success? set statusCode [CkRest_get_ResponseStatusCode $rest] if {$statusCode != 200} then { puts "Error response: $responseBodyStr" puts "Status code: $statusCode, Status text: [CkRest_responseStatusText $rest]" delete_CkRest $rest delete_CkAuthAws $authAws delete_CkFileAccess $fac exit } puts "File successfully uploaded." delete_CkRest $rest delete_CkAuthAws $authAws delete_CkFileAccess $fac |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.