illusionist / flysystem-aliyun-oss
Flysystem adapter for the Aliyun OSS SDK
1.0.1
2022-02-24 06:29 UTC
Requires
- php: >=5.5.9
- aliyuncs/oss-sdk-php: ^2.0
- league/flysystem: ^1.0
Requires (Dev)
- mockery/mockery: 0.9.*
- phpunit/phpunit: ~4.0
This package is auto-updated.
Last update: 2024-12-24 12:40:19 UTC
README
Flysystem adapter for the Aliyun OSS SDK
English | 中文
Advantages
- Support Laravel & Lumen
- Compared with xxtime/flysystem-aliyun-oss, it is more in line with the flysystem interface specification. Because the flysystem interface suggests that the return value is array or bool, but xxtime/flysystem-aliyun-oss is not very strict about exception handling.
- Compared to apollopy/flysystem-aliyun-oss <= 1.2.0 supports visibility get/set.
- Support Dynamically call OSS SDK methods.
ps: The comparison of similar projects is only to highlight the differences. In fact, they are all very good.
Installation
Install via composer
Run the following command to pull in the latest version:
composer require illusionist/flysystem-aliyun-oss
Laravel Install
If your laravel version <=5.4
, Add the service provider to the providers
array in the config/app.php
config file as follows:
'providers' => [ ... Illusionist\Flysystem\Aliyun\OssServiceProvider::class, ]
Lumen Install
Add the following snippet to the bootstrap/app.php
file under the providers section as follows:
... // Add this line $app->register(Illusionist\Flysystem\Aliyun\OssServiceProvider::class);
Config for Laravel/Lumen
Add the adapter config to the disks
array in the config/filesystems.php
config file as follows:
'disks' => [ ... 'aliyun-oss' => [ 'driver' => 'aliyun-oss', /** * The AccessKeyId from OSS or STS. */ 'key' => '<your AccessKeyId>', /** * The AccessKeySecret from OSS or STS */ 'secret' => '<your AccessKeySecret>', /** * The domain name of the datacenter. * * @example: oss-cn-hangzhou.aliyuncs.com */ 'endpoint' => '<endpoint address>', /** * The bucket name for the OSS. */ 'bucket' => '<bucket name>', /** * The security token from STS. */ 'token' => null, /** * If this is the CName and binded in the bucket. * * Values: true or false */ 'cname' => false, /** * Path prefix */ 'prefix' => '', /** * Request header options. * * @example [x-oss-server-side-encryption => 'KMS'] */ 'options' => [] ] ]
Usage
Basic
Please refer to filesystem-api.
use Illusionist\Flysystem\Aliyun\OssAdapter; use League\Flysystem\Filesystem; use OSS\OssClient; $client = new OssClient( '<your AccessKeyId>', '<your AccessKeySecret>', '<endpoint address>' ); $adapter = new OssAdapter($client, '<bucket name>', 'optional-prefix', 'optional-options'); $filesystem = new Filesystem($adapter); $filesystem->has('file.txt'); // Dynamic call SDK method. $adapter->setTimeout(30); $filesystem->getAdapter()->setTimeout(30);
Laravel/Lumen
Please refer to filesystem
use Illuminate\Support\Facades\Storage; Storage::disk('aliyun-oss')->get('path'); // Dynamic call SDK method. Storage::disk('aliyun-oss')->getAdapter()->setTimeout(30);