zoukankan      html  css  js  c++  java
  • 奇妙的 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="用户头像">
    
  • 相关阅读:
    Java关键字static、final使用小结
    JAVA的核心概念:接口(interface)
    Oracle数据泵导入导出数据,建立表空
    web.xml中load-on-startup的作用
    UIApplication 用法解析
    ios-Ineligible Devices 不被识别的设备
    Xcode真机测试could not find developer disk image解决方法
    异常捕获拒绝闪退 让应用从容的崩溃UncaughtExceptionHandler
    Xcode6之后创建Pch预编译文件
    MBProgressHUD的基本使用
  • 原文地址:https://www.cnblogs.com/zhangbao/p/7391032.html
Copyright © 2011-2022 走看看