发现
这是我在做头像上传功能时发现的,下面是图片上传的业务逻辑。
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="用户头像">