laravel 上传文件到阿里云OSS

阿里云 oss 文件系统存储 laravel 5. 你可以像往常一样使用阿里云 OSS 的 laravel 存储适配器。例子的优秀的代码,多种组合,同时做了更多优化,添加了更多完善的接口和插件,制作 Laravel 最好的 OSS 存储扩展。

laravel-admin 文件上传改为异步上传加进度条这篇文章有很大联系感兴趣可以看一下,不看不影响功能使用

安装

首先运行下面命令来给你的Laravel项目安装依赖

composer require jacobcyl/ali-oss-storage:^2.1

然后在您config/app.php将此行添加到提供程序数组中:

Jacobcyl\AliOSS\AliOssServiceProvider::class,


配置

添加下边的代码到配置文件app/filesystems.php中:

'disks'=>[
    ...
    'oss' => [
        'driver'            => 'oss',
        'access_id'         => env('ALIOSS_KEYID', null), //Your Aliyun OSS AccessKeyId
        'access_key'        => env('ALIOSS_KEYSECRET', null), //Your Aliyun OSS AccessKeySecret
        'bucket'            => env('ALIOSS_BUCKETNAME', null), //OSS bucket name
        'endpoint'          => env('ALIOSS_ENDPOINT', null), //<the endpoint of OSS, E.g: oss-cn-hangzhou.aliyuncs.com | custom domain, E.g:img.abc.com> OSS 外网节点或自定义外部域名
        'endpoint_internal' => env('ALIOSS_ENDPOINT_INTERNAL', null), //<internal endpoint [OSS内网节点] 如:oss-cn-shenzhen-internal.aliyuncs.com> v2.0.4 新增配置属性,如果为空,则默认使用 endpoint 配置(由于内网上传有点小问题未解决,请大家暂时不要使用内网节点上传,正在与阿里技术沟通中)
        'cdnDomain'         => env('ALIOSS_DOMAIN', null), //<CDN domain, cdn域名> 如果isCName为true, getUrl会判断cdnDomain是否设定来决定返回的url,如果cdnDomain未设置,则使用endpoint来生成url,否则使用cdn
        'ssl'               => env('ALIOSS_SSL', false), // true to use 'https://' and false to use 'http://'. default is false,
        'isCName'           => env('ALIOSS_CNAME', false), // 是否使用自定义域名,true: 则Storage.url()会使用自定义的cdn或域名生成文件url, false: 则使用外部节点生成url
        'debug'             => env('ALIOSS_DEBUG', true),
    ],
]

然后在文件 .env 中配置你的相关信息:

FILESYSTEM_DRIVER=oss

ALIOSS_KEYID=<Your Aliyun OSS AccessKeyId>
ALIOSS_KEYSECRET=<Your Aliyun OSS AccessKeySecret>
ALIOSS_BUCKETNAME=<OSS bucket name>
ALIOSS_ENDPOINT=<the endpoint of OSS, E.g: oss-cn-hangzhou.aliyuncs.com | custom domain, E.g:img.abc.com>
ALIOSS_ENDPOINT_INTERNAL=<internal endpoint [OSS内网节点] 如:oss-cn-shenzhen-internal.aliyuncs.com>
ALIOSS_DOMAIN=<CDN domain, cdn域名>
ALIOSS_SSL=<true|false>
ALIOSS_CNAME=<true|false>
ALIOSS_DEBUG=<true|false>

注意: 如果你的服务器和你的 OSS Bucket 不在同一个区域的话,请务必不要配置 ALIOSS_ENDPOINT_INTERNAL。

如果配置了 ALIOSS_ENDPOINT_INTERNAL,那么传输将使用阿里云内网,无论是否配置 ALIOSS_CNAME 和 ALIOSS_DOMAIN。

传输优先级: ALIOSS_ENDPOINT_INTERNAL > ALIOSS_CNAME=true && ALIOSS_DOMAIN > ALIOSS_ENDPOINT。

好了,这些你就配置完成了。现在你可以像Laravel Storage一样使用 Aliyun OSS 了。

使用

首先在文件开始位置引用Laravel Storage

use Illuminate\Support\Facades\Storage;

然后你就可以使用Laravel StorageAPI

// 如果你设置的默认文件驱动时oss的话,这一步可以跳过
Storage::disk('oss');

// 获取目录下所有的文件
Storage::disk('oss')->files($directory);
// 递归获取目录下所有的文件
Storage::disk('oss')->allFiles($directory);

// 上传文件 第一个参数是储存位置,第二个参数是文件内容
Storage::disk('oss')->put('path/to/file/file.jpg', $contents);
// 上传指定本地文件到指定位置
Storage::disk('oss')->putFile('path/to/file/file.jpg', 'local/path/to/local_file.jpg');

// 获得指定文件的内容
Storage::disk('oss')->get('path/to/file/file.jpg');
// 判断指定对象是否存在
Storage::disk('oss')->exists('path/to/file/file.jpg');
// 获得指定对象的大小
Storage::disk('oss')->size('path/to/file/file.jpg');、
// 获得指定对象的最后修改时间
Storage::disk('oss')->lastModified('path/to/file/file.jpg');

// 获得指定位置下的所有目录
Storage::disk('oss')->directories($directory);
// 递归获得指定位置下的所有目录
Storage::disk('oss')->allDirectories($directory);

// 复制指定对象到指定位置
Storage::disk('oss')->copy('old/file1.jpg', 'new/file1.jpg');
// 移动指定对象到指定位置
Storage::disk('oss')->move('old/file1.jpg', 'new/file1.jpg');
// 重命名指定对象
Storage::disk('oss')->rename('path/to/file1.jpg', 'path/to/file2.jpg');

// 向指定文件中追加前置内容
Storage::disk('oss')->prepend('file.log', 'Prepended Text');
// 向指定文件中追加内容
Storage::disk('oss')->append('file.log', 'Appended Text');

// 删除指定对象
Storage::disk('oss')->delete('file.jpg');
// 删除多个指定对象
Storage::disk('oss')->delete(['file1.jpg', 'file2.jpg']);

// 创建指定目录
Storage::disk('oss')->makeDirectory($directory);
// 删除指定目录 目录中的所有文件同样会被删除 请慎重使用
Storage::disk('oss')->deleteDirectory($directory);

// 更新新添加函数
// v2.0 添加插件:
// 上传远程文件到指定位置
Storage::disk('oss')->putRemoteFile('target/path/to/file/jacob.jpg', 'http://example.com/jacob.jpg');
// v2.0.1 添加插件:
// 获得指定文件的网址
Storage::disk('oss')->url('path/to/img.jpg'); // get the file url

后发现有一个该基础下的的加强版只更改安装流程其他不变安装方式如下:

首先运行下面命令来给你的Laravel项目安装依赖

composer require wtto/ali-oss-storage

然后你需要在配置文件config/app.php中,添加下边的代码来引用依赖

Wtto\AliOSS\AliOssServiceProvider::class,


使用时除了上方方法还新增方法

// v2.1.1 添加插件:
// 获得私有 Bucket 的指定文件的临时公开网址 默认临时公开失效是 3600 秒
Storage::signUrl('path/to/img.jpg',$timeout);
// v2.3.0 添加插件:
// 获得指定位置的所有对象 包括目录以及文件 文件会放回相关属性
Storage::objects($directory);
// 递归获得指定位置的所有对象 包括目录以及文件 文件会放回相关属性
Storage::allObjects($directory);
// v2.3.1 添加插件:
// 通过url获得文件所在位置
Storage::url2path($url);
// 复制目录
Storage::copyDirectory('path/from/','path/to/');
// 移动目录
Storage::moveDirectory('path/from/','path/to/');
// 重命名目录
Storage::renameDirectory('path/from/','path/to/');
// 分页查询指定位置的对象 并返回下一页的标记
Storage::objects($directory, $page_size = null, $next_marker = '');

这个加强版并未使用过,只是偶然发现,里面增添了几个功能,后边会测试功能的可用性。

0 评论
内联反馈
查看所有评论