07/09/2018, 10:03

Tìm hiểu về File Storage của Laravel

Laravel cung cấp cho người dùng một giải pháp để quản lý file cực kỳ tiện lợi và hữu ích - đó là File Storage. Tính năng này bạn hoàn toàn có thể dùng trên các Framework khác vì nó là một package của Frank de Jonge. Bạn có thể xem package tại đây. Với File Storage bạn có thể thao tác với các ...

  • Laravel cung cấp cho người dùng một giải pháp để quản lý file cực kỳ tiện lợi và hữu ích - đó là File Storage. Tính năng này bạn hoàn toàn có thể dùng trên các Framework khác vì nó là một package của Frank de Jonge. Bạn có thể xem package tại đây.
  • Với File Storage bạn có thể thao tác với các file ở local, Rackspace Cloud Storage và cả Amazon S3.
  • Bạn có thể config File Storage tại file config/filesystems.php.
  • Driver mà Laravel hỗ trợ: "local", "ftp", "sftp", "s3", "rackspace".

Local

  • Để sử dụng và download các file trên web, bạn cần phải chạy lệnh sau để tạo ra một symbolic link trong thư mục public của Laravel: php artisan storage:link.
  • Mặc định, nó sẽ link đến đường dẫn storage/app/public. Bạn có thể config đường dẫn mà nó link đến tại dòng: 'root' => storage_path('app/public').
  • Để thao tác với thao trên web, bạn có thể dụng: asset('storage/filename');.
  • Để thao tác với file local, bạn có thể dùng Storage::disk('local')->put('file.txt', 'Contents');. Vì mặc định laravel sẽ dùng local nên bạn chỉ cần sử dụng Storage::put('file.txt', 'Contents');

S3 driver

Để lưu file lên Amazon S3 bạn cần install thêm package đó là:

Amazon S3: league/flysystem-aws-s3-v3 ~1.0`

Sau khi cài xong package, bạn cần config các thông số trong config/filesystems.php:

's3' => [
    'driver' => 's3',
    'key' => env('AWS_ACCESS_KEY_ID'),
    'secret' => env('AWS_SECRET_ACCESS_KEY'),
    'region' => env('AWS_DEFAULT_REGION'),
    'bucket' => env('AWS_BUCKET'),
    'url' => env('AWS_URL'),
],

FTP Driver

Bạn có thể sử dụng FTP Driver mà không cần thêm package giống như ở trên. Tuy nhiên, mặc định FTP sẽ không có sẵn trong config/filesystems.php. Để sử dụng FTP bạn phải thêm vào config/filesystems.php:

'ftp' => [
    'driver'   => 'ftp',
    'host'     => 'ftp.example.com',
    'username' => 'your-username',
    'password' => 'your-password',

    // Optional FTP Settings...
    // 'port'     => 21,
    // 'root'     => ',
    // 'passive'  => true,
    // 'ssl'      => true,
    // 'timeout'  => 30,
],

Như đã nói ở trên, mặc định ổ đĩa sẽ là local vì vậy nếu bạn muốn thao tác với Amazon S3 bạn sẽ cần sử dụng phương thức disk.

Mặc định:

Storage::put('avatars/1', $fileContents);

S3:

Storage::disk('s3')->put('avatars/1', $fileContents);

Rackspace

Storage::disk('rackspace')->put('avatars/1', $fileContents);

Để lấy nội dung file:

$contents = Storage::get('file.jpg');

Để kiểm tra file có tồn tại không

Storage::exists('file.jpg');

Để lấy URL của file

$url = Storage::url('file1.jpg');

Lưu tạm file (chỉ hỗ trợ s3 và rackspace)

$url = Storage::temporaryUrl(
    'file1.jpg', now()->addMinutes(5)
);

File Metadata

Bạn có thể lấy thông tin của 1 file bằng cách sử dụng:

Storage::getMetaData('file.txt');

Lấy size:

$size = Storage::size('file1.jpg');

Lấy thời gian thao tác cuối

$time = Storage::lastModified('file1.jpg');

Copy và moving file

Storage::copy('old/file1.jpg', 'new/file1.jpg');
Storage::move('old/file1.jpg', 'new/file1.jpg');

Chắc hẳn bạn đã từng làm qua tính năng upload file, hay ít nhất là upload avatar cho user hoặc thumbnail cho sản phẩm chẳng hạn. Laravel hỗ trợ bạn làm điều này một cách dễ dàng thông qua Request:

$path = $request->file('avatar')->store('public/avatars');

Hoặc thông qua Storage:

$path = Storage::putFile('avatars', $request->file('avatar'));

Lưu ý: mặc định với cách này Laravel sẽ lưu file dưới 1 unique name. Bạn có thể lấy filename bằng cách sử dụng:

$request->file('avatar')->hashName();

Upload dưới tên khác

Như cách ở trên thì Laravel sẽ tự động thêm tên cho file mà không trùng tên với các file có sẵn. Nhưng bạn cũng có thể lưu file với một tên tùy ý bằng cách sử dụng:

$path = $request->file('avatar')->storeAs(
    'avatars', $request->user()->id
);

Hoặc

$path = Storage::putFileAs(
    'avatars', $request->file('avatar'), $request->user()->id
);

Upload vào ổ đĩa khác

Ví dụ bạn muốn upload lên Amazon S3:

$path = $request->file('avatar')->store(
    'avatars/'.$request->user()->id, 's3'
);

Bạn có thể xóa file bằng cách sử dụng:

Storage::delete('file.jpg'); // Xóa 1 file
Storage::delete(['file1.jpg', 'file2.jpg']); // Xóa nhiều file

Hoặc xóa file trên Amazone S3:

Storage::disk('s3')->delete('folder_path/file_name.jpg');

Lấy các file trong thư mục

$files = Storage::files('path');

Lấy tất cả các file con trong thư mục cùng với tất cả các file trong các thư mục con

$files = Storage::allFiles('path');

Tạo thư mục

Storage::makeDirectory('ten-thu-muc');

Xóa thư mục

Storage::deleteDirectory($directory);

Nguồn: https://laravel.com/docs/5.5/filesystem

0