ajoy39 / laravel-storage-azure
An Azure Blob Storage driver for Laravel Storage
Installs: 18 452
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 0
Forks: 2
Open Issues: 6
pkg:composer/ajoy39/laravel-storage-azure
Requires
Requires (Dev)
- orchestra/testbench: ^6.0.0
- phpunit/phpunit: ^9.0.0
Suggests
- league/flysystem-cached-adapter: For increased filesystem perfomance when using azure storage
- dev-master
- v1.0.0
- v0.2
- v0.1
- dev-dependabot/composer/orchestra/testbench-6.37.0
- dev-dependabot/composer/symfony/http-kernel-5.4.27
- dev-dependabot/composer/guzzlehttp/psr7-1.9.1
- dev-dependabot/composer/laravel/framework-8.83.27
- dev-dependabot/composer/guzzlehttp/guzzle-6.5.8
- dev-dependabot/composer/league/flysystem-1.1.4
This package is auto-updated.
Last update: 2025-10-25 08:38:06 UTC
README
This package provides an easy, out of the box, service provider for using Azure Blob Storage to back Laravel's Storage service.
Installation
composer require ajoy39/laravel-storage-azure
Configuration
There are two options when setting up the connection, you can use the connection string provided by Azure or enter the values individually.
Connection String Method
In config/filesystem.php add the following to your storage drivers array
'azure' => [
    'driver' => 'azure-blob-storage',
    'connection_string' => env('AZURE_BLOB_STORAGE_CONNECTION_STRING'),
    'container' => env('AZURE_BLOB_STORAGE_CONTAINER')
]
Fill in the values in your environment file
AZURE_BLOB_STORAGE_CONNECTION_STRING= 
AZURE_BLOB_STORAGE_CONTAINER=
Explicit Configuration Method
In config/filesystem.php add the following to your storage drivers array
'azure' => [
    'driver' => 'azure-blob-storage',
    'account_name' => env('AZURE_BLOB_STORAGE_ACCOUNT_NAME'),
    'account_key' => env('AZURE_BLOB_STORAGE_ACCOUNT_KEY'),
    'container' => env('AZURE_BLOB_STORAGE_CONTAINER')
]
And then fill in the environment variables in your .env file or enviroment management solution
AZURE_BLOB_STORAGE_ACCOUNT_NAME=
AZURE_BLOB_STORAGE_ACCOUNT_KEY=
AZURE_BLOB_STORAGE_CONTAINER=
If you are using Azure Gov Cloud then you will have to add the endpoint suffix to the configuration array and environment variables. This step is not necassary for the connection string method, as the connection string will already have the endpoint_suffix defined.
'azure' => [
    'driver' => 'azure-blob-storage',
    'account_name' => env('AZURE_BLOB_STORAGE_ACCOUNT_NAME'),
    'account_key' => env('AZURE_BLOB_STORAGE_ACCOUNT_KEY'),
    'endpoint_suffix' => env('AZURE_BLOB_STORAGE_ENDPOINT_SUFFIX')
    'container' => env('AZURE_BLOB_STORAGE_CONTAINER')
]
AZURE_BLOB_STORAGE_ACCOUNT_NAME=
AZURE_BLOB_STORAGE_ACCOUNT_KEY=
AZURE_BLOB_STORAGE_CONTAINER=
AZURE_BLOB_STORAGE_ENDPOINT_SUFFIX
Usage
You can now use Storage::disk('azure') right away. If you would like to set azure as the default storage disk, simply set the FILESYSTEM_DRIVER environment variable
FILESYSTEM_DRIVER=azure