Help Center> Object Storage Service> SDK Reference> PHP> Object Download> Performing a Streaming Download

Performing a Streaming Download

If you have any questions during development, post them on the Issues page of GitHub. For details about parameters and usage of each API, see the API Reference

Sample code:

// Import the dependency library.
require 'vendor/autoload.php';
// Import the SDK code library during source code installation.
// require 'obs-autoloader.php';
// Declare the namespace.
use Obs\ObsClient;
// Create an instance of ObsClient.
$obsClient = new ObsClient ( [
       'key' => '*** Provide your Access Key ***',
       'secret' => '*** Provide your Secret Key ***',
       'endpoint' => 'https://your-endpoint'
] );

$resp = $obsClient -> getObject([
       'Bucket' => 'bucketname',
       'Key' => 'objectname',
       'SaveAsStream' => true
]);

printf("RequestId:%s\n", $resp['RequestId']);
printf("Object Content:\n");
while(!$resp['Body'] -> eof()){
       echo $resp['Body'] -> read(65536);
}
  • Use the SaveAsStream parameter to specify the download mode to streaming download.
  • Body in the returned result is a readable GuzzleHttp\Psr7\StreamInterface object and can be used to save the object to a local directory or to the memory.