奇妙的 Storage::url

发现

这是我在做头像上传功能时发现的,下面是图片上传的业务逻辑。

class AvatarController extends Controller
{
    public function update(Request $request)
    {
        $this->validate($request, [
            'avatar' => 'required|image|dimensions:max_width=400,max_height=400',
        ], [
            'avatar.required' => '请先选择上传的头像。',
            'avatar.dimensions' => '上传头像的宽高都不能大于 400 像素。',
        ]);

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

        if ($avatar->isValid()) {
            $user = Auth::user();

            $path = Storage::putFile('public/uploads/avatars', $avatar);
            $user->avatar = Storage::url($path);
            $user->save();
        }

        return back();
    }
}

$avatar 是从页面接收过来的头像图片。你可能从未想过,短短三行代码就实现了图片上传:

$path = Storage::putFile('public/uploads/avatars', $avatar);
$user->avatar = Storage::url($path);
$user->save();

保存图片

如果没有使用 disk 方法指定「硬盘」,Storage 门面默认使用的硬盘就是 local,对应存储路径是 storage/app。所以

$path = Storage::putFile('public/uploads/avatars', $avatar);

产生的上传路径($path)的值类似:public/uploads/avatars/iT8Lg6mmF8qtlskbl54tlsNlYmJLLZnAZzkZsFJH.png,图片实际存储的位置在 /path/to/myapp/storage/app/public/uploads/avatars/iT8Lg6mmF8qtlskbl54tlsNlYmJLLZnAZzkZsFJH.png

生成图片 URL

黑科技来了。你知道 Storage::url($path) 会产生什么结果吗?答案揭晓——/storage/uploads/avatars/iT8Lg6mmF8qtlskbl54tlsNlYmJLLZnAZzkZsFJH.png

Oops!$path 的 「public」被去掉,然后在头部加了 /storage。这就是 Laravel 的 careful。

访问图片

<img src="{{ asset(Auth::user()->avatar) }}" alt="用户头像">
posted @ 2017-08-18 17:54  Hi!张宝  阅读(209)  评论(0编辑  收藏  举报