selden1992 / think-flysystem
thinkphp 集成的文件系统,本地存储,第三发存储提供一致的API
Installs: 139
Dependents: 0
Suggesters: 0
Security: 0
Stars: 12
Watchers: 4
Forks: 7
Type:think-extension
Requires
- php: >=5.6.4
- league/flysystem: ^1.0
This package is not auto-updated.
Last update: 2025-01-05 04:22:39 UTC
README
think PHP5集成Filesystem
think-filesystem基于 Frank de Jonge 开发的 PHP 包 Flysystem 提供了强大的文件系统抽象。think-filesystem 文件系统集成是中文化和简单化,当然也做了一下本地化封装。
安装
The preferred way to install this extension is through composer.
Either run
$ composer require selden1992/think-flysystem
or add
"selden1992/think-flysystem": "dev-master"
to the require
section of your composer.json
file.
配置
复制 /vendor/selden1992/think-flysystem/config/flysystem.php 到 CONF_PATH.'extra/flysystem.php'
<?php /** * 演示配置 */ return [ // 默认驱动 'default'=>'local', // 本地驱动 'local'=>[ 'adapter_class'=>\Think\flysystem\adapter\Local::class, // 跟目录 'root'=>'./files/', // 权限参数 'permissions'=>[ 'file' => [ 'public' => 0744, 'private' => 0700, ], 'dir' => [ 'public' => 0755, 'private' => 0700, ] ], // 目录别名 'alias'=>[ 'image'=>'image/user/', ], ], // ftp 扩展 'ftp'=>[ 'adapter_class'=>\Think\flysystem\adapter\Ftp::class, // 权限参数 'permissions'=>[ 'host' => 'ftp.example.com', 'username' => 'username', 'password' => 'password', /** optional config settings */ 'port' => 21, 'root' => '/path/to/root', 'passive' => true, 'ssl' => true, 'timeout' => 30, ], // 目录别名 'alias'=>[ 'image'=>'image/user/', ], ], // sftp 扩展 'sftp'=>[ 'adapter_class'=>\Think\flysystem\adapter\Sftp::class, // 权限参数 'permissions'=>[ 'host' => 'example.com', 'port' => 21, 'username' => 'username', 'password' => 'password', 'privateKey' => 'path/to/or/contents/of/privatekey', 'root' => '/path/to/root', 'timeout' => 10, ], // 目录别名 'alias'=>[ 'image'=>'image/user/', ], ], ];
如果ftp提示不能写,可以设置一个777权限的目录调试是否权限影响到
putenv(‘TMPDIR=/Users/cyz/web/test’);
普通使用
<?php namespace app\index\controller; use Think\flysystem\Files; class Index { public function index() { // 普通写入 Files::put('log/test.log',time()); // 目录别名写入 Files::alias('log_alias')->put('test2.log',time()); // 指定驱动 Files::disk('local')->put('test3.log',time()); // 普通读取 echo Files::read('log/test.log'); // 目录别名读取 echo Files::alias('log_alias')->read('test2.log'); // 复制 Files::copy('log/test.log','log/image1.log'); // 第二参数路径使用别名 Files::copy('log/test.log',['alias'=>'local','path'=>'image1.log']); // 获取别名真实路径 echo Files::getAliasPath('image'); /** * ftp 操作 */ Files::disk('ftp')->put('log/test4.log',time()); echo Files::disk('ftp')->alias('log_alias')->read('test4.log'); /** * sftp 操作 * 需要按 composer require league/flysystem-sftp */ Files::disk('sftp')->put('log/test4.log',time()); echo Files::disk('sftp')->alias('log_alias')->read('test4.log'); } }
alias目录别名的作用在于快捷更换目录,例如开发阶段,log_alias指向root/log/下,部署阶段更改为 web/log/
其他使用方法和flysystem一致
API 一般用法
写文件
Files::write('path/to/file.txt', 'contents');
更新文件
Files::update('path/to/file.txt', 'new contents');
写或更新文件
Files::put('path/to/file.txt', 'contents');
读取文件
$contents = Files::read('path/to/file.txt');
检查文件是否存在
$exists = Files::has('path/to/file.txt');
注意:这只对文件而不是目录具有一致的行为。在Flysystem中,目录不太重要,它们是隐式创建的,常常被忽略,因为不是每个适配器(文件系统类型)都支持目录。
删除文件
Files::delete('path/to/file.txt');
读取和删除
$contents = Files::readAndDelete('path/to/file.txt');
重命名文件
Files::rename('filename.txt', 'newname.txt');
复制文件
Files::copy('filename.txt', 'duplicate.txt');
获取Mimetypes
$mimetype = Files::getMimetype('path/to/file.txt');
获取时间戳
$timestamp = Files::getTimestamp('path/to/file.txt');
获取文件大小
$size = Files::getSize('path/to/file.txt');
创建目录
Files::createDir('path/to/nested/directory');
当写入更深的路径时,也隐含地指定了目录
Files::write('path/to/file.txt', 'contents');
删除目录
Files::deleteDir('path/to/directory');
上述方法将递归删除目录
注意:Flysystem API使用的所有路径都是相对于适配器根目录的。