文件系统的配置文件位于
config/filesystems.php
。在这个文件中你可以配置所有「磁盘」。每个磁盘代表特定的存储驱动及存储位置。
公共磁盘
public 磁盘适用于要公开访问的文件。默认情况下, public 磁盘使用 local 驱动,并且将这些文件存储在
storage/app/public 目录下为了使它们能通过网络访问,你需要
创建
从 public/storage 到 storage/app/public 的
符号链接
创建符号链接
php artisan storage:link
一旦创建成功,public目录下就会有 storage这个文件,这个文件可以访问到storage目录下的public
本地驱动
使用 local 驱动时,所有文件操作都与 filesystems 配置文件中定义的 root 目录相关。 默认情况下,此值设置为
storage/app 目录
Storage::disk('local')->put('file.txt', 'Contents');
获取磁盘实例
如果不使用disk()就会存储到默认磁盘,默认磁盘的local
创建一个磁盘文件–put
Storage::put('xiao.txt', 'xiaoxin');
如果应用程序要与多个磁盘进行互操作,可使用 Storage 门面中的 disk 方法对特定磁盘上的文件进行操作
Storage::disk('public')->put('12.txt', 'xiaoxin');
检索文件
get 方法可以用于检索文件的内容
,此方法返回该文件的原始字符串内容。
$content = Storage::get('11.txt');
dd($content);
exists 方法可以用来判断磁盘上是否存在指定的文件
$exists = Storage::disk('local')->exists('11.txt');
dd($exists);
missing 方法可以用来判断磁盘上是否缺少指定的文件
$missing = Storage::disk('local')->missing('11.txt');
dd($missing);
文件 URLs
获取文件URL – url 方法来获取给定文件的 URL
$url = Storage::url('11.txt');
dd($url);
如果你使用的是 local 驱动,通常会给指定的路径前加上 /storage 并返回文件的相对 URL 地址。如果使用的是
s3驱动,则返回完整的远程 URL
$url = Storage::disk('public')->url('11.txt');
dd($url);
文件元数据
$size = Storage::size('11.txt');//返回数据的大小
lastModified 方法返回文件最后一次被修改的 UNIX 时间戳:
$time = Storage::lastModified('file.jpg');
自动流式传输
可以使用 putFile 或 putFileAs 方法来让 Laravel 自动将给定的文件流式传输到您的存储位置
// 自动为文件名生成唯一 ID ……
Storage::putFile('photos', new File('/path/to/photo'));
// 手动指定文件名……
Storage::putFileAs('photos', new File('/path/to/photo'), 'photo.jpg');
文件数据写入
prepend 和 append 方法允许您在文件的开头和末尾写入数据:
Storage::prepend('file.log', 'Prepended Text');
Storage::append('file.log', 'Appended Text');
复制和移动文件
使用 copy 方法来复制一个已经存在的文件到磁盘上的一个新位置,而 move 方法则可以重命名或移动一个已经存在的文件到新位置:
Storage::copy('old/file.jpg', 'new/file.jpg');
Storage::move('old/file.jpg', 'new/file.jpg');
删除文件
delete 方法接收一个文件名或一个文件名数组来将其从磁盘中删除
Storage::delete('file.jpg');