云端 | 多文件上传 | Base64图片上传 | 服务器文件上传 |
---|---|---|---|
🍏 私有云 | ✅ | -- | ✅ |
🍓 阿里云 | ✅ | ✅ | ✅ |
🍋 腾讯云 | ✅ | ✅ | ✅ |
🍇 七牛云 | ✅ | ✅ | ✅ |
🍇 亚马逊(S3) | ✅ | ✅ | ✅ |
composer require tinywan/storage
$res = Tinywan\Storage\Storage::uploadFile();
var_dump(json_encode($res));
v1.0.0
版本之后不需要调用此方法Tinywan\Storage\Storage::config()
初始化,会自动初始化,默认为配置文件app.php
默认配置default
配置上传适配器。
[
{
"key": "webman",
"origin_name": "常用编程软件和工具.xlsx",
"save_name": "03414c9bdaf7a38148742c87b96b8167.xlsx",
"save_path": "runtime/storage/03414c9bdaf7a38148742c87b96b8167.xlsx",
"save_path": "/var/www/webman-admin/public/storage/03414c9bdaf7a38148742c87b96b8167.xlsx",
"url": "/storage/fd2d472da56c71a6da0a5251f5e1b586.png",
"uniqid ": "03414c9bdaf7a38148742c87b96b8167",
"size": 15050,
"mime_type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
"extension": "xlsx"
}
...
]
失败,抛出
StorageAdapterException
异常
字段 | 描述 | 示例值 |
---|---|---|
key | 上传文件key | webman |
origin_name | 原始文件名 | 常用编程软件和工具.xlsx |
save_name | 保存文件名 | 03414c9bdaf7a38148742c87b96b8167.xlsx |
save_path | 文件保存路径(相对) | /var/www/webman-admin/runtime/storage/03414c9bdaf7a38148742c87b96b8167.xlsx |
url | url访问路径 | /storage/03414c9bdaf7a38148742c87b96b8167.xlsx |
unique_id | uniqid | 03414c9bdaf7a38148742c87b96b8167 |
size | 文件大小 | 15050(字节) |
mime_type | 文件类型 | application/vnd.openxmlformats-officedocument.spreadsheetml.sheet |
extension | 文件扩展名 | xlsx |
默认情况下是上传到本地服务器,会在runtime/storage
目录下面生成以当前日期为子目录,以文件流的sha1编码为文件名的文件,例如上面生成的文件名可能是:
runtime/storage/fd2d472da56c71a6da0a5251f5e1b586.png
如果你希望上传的文件是可以直接访问或者下载的话,可以使用public
存储方式。
你可以在config/plugin/tinywan/storage/app.php
配置文件中配置上传根目录,例如:
'local' => [
'adapter' => \Tinywan\Storage\Adapter\LocalAdapter::class,
'root' => public_path() . '/storage',
],
浏览器访问:http://127.0.0.1:8787/storage/fd2d472da56c71a6da0a5251f5e1b586.png
支持使用验证类对上传文件的验证,包括文件大小、文件类型和后缀
字段 | 描述 | 示例值 |
---|---|---|
single_limit | 单个文件的大小限制,默认200M | 1024 * 1024 * 200 |
total_limit | 所有文件的大小限制,默认200M | 1024 * 1024 * 200 |
nums | 文件数量限制,默认10 | 10 |
include | 被允许的文件类型列表 | ['xlsx','pdf'] |
exclude | 不被允许的文件类型列表 | ['png','jpg'] |
composer require aliyuncs/oss-sdk-php
composer require qcloud/cos-sdk-v5
composer require qiniu/php-sdk
composer require league/flysystem-aws-s3-v3
使用场景: 前端直接截图(头像、Canvas等)一个Base64数据流的图片直接上传到云端
{
"extension": "png",
"base64": "data:image/jpeg;base64,/9j/4AAQSkxxxxxxxxxxxxZJRgABvtyQBIr/MPTPTP/2Q=="
}
public function upload(Request $request)
{
$base64 = $request->post('base64');
$response = \Tinywan\Storage\Storage::disk(\Tinywan\Storage\Storage::MODE_OSS, false)->uploadBase64($base64,'png');
var_dump($response);
}
v1.0.0
版本之后不需要调用此方法Tinywan\Storage\Storage::config()
初始化,会自动初始化,默认为配置文件app.php
默认配置default
配置上传适配器。
{
"save_path": "storage/20220402213639624851671439e.png",
"url": "http://webman.oss.tinywan.com/storage/20220402213639624851671439e.png",
"unique_id": "20220402213639624851671439e",
"size": 11802,
"extension": "png"
}
使用场景: 服务端导出文件需要上传到云端存储,或者零时下载文件存储。
$serverFile = runtime_path() . DIRECTORY_SEPARATOR . 'storage/webman.png';
$res = \Tinywan\Storage\Storage::disk(\Tinywan\Storage\Storage::MODE_OSS, false)->uploadServerFile($serverFile);
v1.0.0
版本之后不需要调用此方法Tinywan\Storage\Storage::config()
初始化,会自动初始化,默认为配置文件app.php
默认配置default
配置上传适配器。
{
"origin_name": "/var/www/webman-admin/runtime/storage/webman.png",
"save_path": "storage/6edf04d7c26f020cf5e46e6457620220402213414.png",
"url": "http://webman.oss.tinywan.com/storage/6ed9ffd54d0df57620220402213414.png",
"unique_id": "6edf04d7c26f020cf5e46e6403213414",
"size": 3505604,
"extension": "png"
}
vendor/bin/phpstan analyse src
vendor/bin/php-cs-fixer fix src