maxlcoder / laravel-oss
阿里云 OSS Laravel 扩展
1.0.3
2025-02-17 09:50 UTC
Requires
- aliyuncs/oss-sdk-php: ^2.7
- laravel/framework: ^9.0
README
配置
配置文件在 config/oss.php
文件中,内容如下:
return [ 'endpoint_upload' => env('OSS_ENDPOINT_UPLOAD'), 'endpoint' => env('OSS_ENDPOINT'), 'access_key' => env('OSS_ACCESS_KEY'), 'secret_key' => env('OSS_SECRET_KEY'), 'bucket' => env('OSS_BUCKET'), 'path' => env('OSS_PATH', '') ];
重点配置说明
endpoint_upload
: 表示和阿里云进行 API 交互的域名,形如 oss-cn-hangzhou.aliyuncs.com
,例如文件上传,相关设置之类。注意这里如果是纯后端和 OSS 交互,且服务是部署在阿里云上,这里可以考虑使用内网域名
endpoint
: 文件域名通常作为文件下载的预览的地址域名,通常使用 bucket 域名,形如 https://[buckent-name].oss-cn-hangzhou.aliyuncs.com
,如果是不想暴露 bucket 域名也可以使用自定义域名。
域名支持情况
域名 | endpoint_upload 上行(API 交互) | endpoint 下行(文件下载预览) |
---|---|---|
地域域名(oss-cn-hangzhou.aliyuncs.com) | 支持 | 不支持 |
bucket 域名(https://[buckent-name].oss-cn-hangzhou.aliyuncs.com) | 支持 | 支持 |
自定义域名(https://xxx.xxx.com) | 支持 | 支持 |
因此这里保留两个 endpoint 配置,便于支持各种情况
path
: 考虑到单个 bucket 既作为开发环境,又作为生成环境,提供一个 bucket 下的顶层目录来区分不同环境下产生的文件。如果不同环境有不同的 bucket 或者不区分环境,该配置可以忽略
方法
服务端上传加密签名
$dir
设置文件前缀,防止文件重复,未传值时,系统默认使用 日期+uuid+随机码
进行文件前缀防止重复
$maxSize
最大支持的上传文件大小(字节数)
public function signUpload($dir = '', $maxSize = 1048576000){ ... }
返回参数
return [ 'access_id' => $accessKeyId, 'host' => $host, 'policy' => $base64Policy, 'signature' => $signature, 'dir' => $dir, ];