4

我需要帮助理解 Laravel 的文件存储系统。我正在创建一个需要上传用户驾驶执照照片的应用程序。这显然是敏感信息。除非管理员正在查看它,否则我想将此图像保留在 Internet 之外。我的理解是,我必须将内容保存到 storage>app>public 中的 public 目录,并创建指向 public>storage 文件夹的符号链接。我已经完成了,并且工作正常。我保存了数据库的路径,程序可以显示它,但如果我可以避免的话,我不希望事情出现在公用文件夹中。

有没有办法将图像/文件保存到存储系统中的私人文件夹,然后通过视图访问它?如果我这样做,它是否会将该图像保持为“私有”,以便它不会存储在某个不在“公共”文件夹中的缓存中?符号链接是否以我想要的方式保护存储文件夹中的文件,或者它是否真正使所有文件都可供公众使用?

任何有助于理解这一点的帮助将不胜感激。

4

1 回答 1

9

您所说的是正确的,其中的文件storage/app/public是公开的。这就是为什么你必须创建一个私有目录,比如说storage/app/private,然后在这里上传你的敏感文件。

您可能想在您的config/filesystems.php:

'private' => [
    'driver' => 'local',
    'root' => storage_path('app/private'),
],

如果您想访问您的私人文件。为此创建一条路线:

Route::get('/private-files/{file?}','FileController@get')->where('file', '(.*)');

然后在 中FileController.php,您将有类似这样的内容(这只是一个示例,在此处编辑代码以检查用户是否为管理员):

<?php
namespace App\Http\Controllers;

use Auth;
use Storage;
use App\Http\Controllers\Controller;

class FileController extends Controller {

    public function __construct()
    {
        $this->middleware('auth');
    }

    public function get($file)
    {
        return Storage::disk('private')->get($file);
    }

 }
于 2019-08-12T14:13:46.720 回答