奇妙的 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="用户头像">

转载于:https://www.cnblogs.com/zhangbao/p/7391032.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值