Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) REST Read Response with Stream APIDemonstrates how to make a REST call that returns a binary body, and to receive the body through a stream API.
use chilkat(); # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $rest = chilkat::CkRest->new(); # Connect to the Amazon AWS REST server. $bTls = 1; $port = 443; $bAutoReconnect = 1; $success = $rest->Connect("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. $authAws = chilkat::CkAuthAws->new(); $authAws->put_AccessKey("AWS_ACCESS_KEY"); $authAws->put_SecretKey("AWS_SECRET_KEY"); $authAws->put_ServiceName("s3"); $success = $rest->SetAuthAws($authAws); # Set the bucket name via the HOST header. # In this case, the bucket name is "chilkat100". $rest->put_Host("chilkat100.s3.amazonaws.com"); # Send the request to download the JPG. $success = $rest->SendReqNoBody("GET","/starfish.jpg"); if ($success != 1) { print $rest->lastErrorText() . "\r\n"; exit; } # Read the response header. $responseStatusCode = $rest->ReadResponseHeader(); if ($responseStatusCode < 0) { print $rest->lastErrorText() . "\r\n"; exit; } print "Response status code = " . $responseStatusCode . "\r\n"; # We expect a 200 response status if the JPG data is coming. # Otherwise, we'll get a string response body with an error message(or no response body). if ($responseStatusCode != 200) { $errResponse = $rest->readRespBodyString(); if ($rest->get_LastMethodSuccess() != 1) { print $rest->lastErrorText() . "\r\n"; } else { print $errResponse . "\r\n"; } exit; } $bodyStream = chilkat::CkStream->new(); # Set a 10 second read timeout for the stream. # (Give up if no data arrives within 10 seconds after calling a read method.) $bodyStream->put_ReadTimeoutMs(10000); # Create a background thread task to read the response body (which feeds # it to the bodyStream object.) # readResponseBodyTask is a Task $readResponseBodyTask = $rest->ReadRespBodyStreamAsync($bodyStream,1); # Start the task. $success = $readResponseBodyTask->Run(); # The application can now read the bodyStream... $nextChunk = chilkat::CkByteData->new(); while (($bodyStream->get_EndOfStream() != 1)) { # Read the next chunk of bytes (whatever is immediately available, # or wait for more data (up to 10 seconds because we set the stream's ReadTimeoutMs property) $success = $bodyStream->ReadBytes($nextChunk); if ($success != 1) { print "Failed to receive more response data." . "\r\n"; # Make sure the background task is aborted/cancelled. $success = $readResponseBodyTask->Cancel(); exit; } # OK.. the app has the next chunk of the body, and may do whatever it wishes with it... # See the CkByteData online reference documentation for # information about accessing and manipulating the byte data. } print "Successfully received the entire response body." . "\r\n"; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.