laravel-filesystem 文件系统

v2.1.2 版本
2022-09-18 版本更新时间
23 安装
2 star

webman-tech/laravel-filesystem

Laravel illuminate/filesystem for webman

介绍

站在巨人(laravel)的肩膀上使文件存储使用更加可靠便捷

所有方法和配置与 laravel 几乎一模一样,因此使用方式完全参考 Laravel文档 即可

安装

由于 laravel 9 升级了 league/flysystem 到 3.x,详见Laravel9升级说明
,低于 larval 9 的版本需要使用 league/flysystem 1.x 的版本
,因此安装该依赖需要手动安装 illuminate/filesystemleague/flysystem

  1. 安装 webman-tech/laravel-filesystem
composer require webman-tech/laravel-filesystem
  1. 安装 league/flysystem

根据 illuminate/filesystem 安装后的版本(通过 composer info illuminate/filesystem 查看)

# illuminate/filesystem < 9.0
composer require league/flysystem:~1.1
# illuminate/filesystem >= 9.0
composer require league/flysystem

使用

所有 API 同 laravel,以下仅对有些特殊的操作做说明

目录权限问题

Unix 系统下需要给予 storage/app 目录写权限

Facade 入口

使用 WebmanTech\LaravelFilesystem\Facades\File 代替 Illuminate\Support\Facades\File

使用 WebmanTech\LaravelFilesystem\Facades\Storage 代替 Illuminate\Support\Facades\Storage

建立软链

php webman storage:link

建立软链之后建议将软链(如 /public/storage)加入根目录下的 .gitignore

同 Laravel,可以支持自定义建立多个对外的路劲软链

Request 文件上传

原 Laravel 下通过 $request()->file() 之后的快捷文件操作,需要使用 webman-tech/polyfill 来支持

安装

composer require webman-tech/polyfill illuminate/http

使用

<?php

namespace app\controller;

use support\Request;
use WebmanTech\Polyfill\LaravelRequest;
use WebmanTech\Polyfill\LaravelUploadedFile;

class UserAvatarController
{
    public function update(Request $request)
    {
        $path = LaravelRequest::wrapper($request)->file('file')->store('avatars');
        // 或者
        $path = LaravelUploadedFile::wrapper($request->file('avatar'))->store('avatars');

        return response($path);
    }
}

自定义文件系统

通过在 filesystems.php 配置文件的 extends 中添加驱动(驱动可以通过实现 WebmanTech\LaravelFilesystem\Extend\ExtendInterface 来快速创建),
然后在 disks 中添加对应的实例即可

目前提供以下非 Laravel 官方库支持的文件系统,可自行参考替换相应的实现

Aliyun OSS

使用 iidestiny/flysystem-oss

# illuminate/filesystem < 9.0
composer require iidestiny/flysystem-oss:~2.7
# illuminate/filesystem >= 9.0
composer require iidestiny/flysystem-oss

QiNiu

使用 overtrue/flysystem-qiniu

# illuminate/filesystem < 9.0
composer require overtrue/flysystem-qiniu:~1
# illuminate/filesystem >= 9.0
composer require overtrue/flysystem-qiniu

Tencent COS

使用 overtrue/flysystem-cos

# illuminate/filesystem < 9.0
composer require overtrue/flysystem-cos:~3
# illuminate/filesystem >= 9.0
composer require oovertrue/flysystem-cos