laravel图片上传,但是图片较大我们进行裁切处理

柔光的暖阳◎ 2022-03-31 12:56 443阅读 0赞

先说一下裁切扩展

安装扩展包

  1. Composer 安装

    $ composer require intervention/image

  2. 配置信息

执行以下命令获取配置信息:

  1. $ php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"

打开 config/image.php 文件可以看到只有一个驱动器的选项,支持的值有 GD 库 和 ImageMagic:

开始裁剪

我们将裁切的逻辑写在 ImageUploadHandler 中,请将以下代码替换:

app/Handlers/ImageUploadHandler.php

  1. <?php
  2. namespace App\Handlers;
  3. use Image;
  4. class ImageUploadHandler
  5. {
  6. protected $allowed_ext = ["png", "jpg", "gif", 'jpeg'];
  7. public function save($file, $folder, $file_prefix, $max_width = false)
  8. {
  9. // 构建存储的文件夹规则,值如:uploads/images/avatars/201709/21/
  10. // 文件夹切割能让查找效率更高。
  11. $folder_name = "uploads/images/$folder/" . date("Ym/d", time());
  12. // 文件具体存储的物理路径,`public_path()` 获取的是 `public` 文件夹的物理路径。
  13. // 值如:/home/vagrant/Code/larabbs/public/uploads/images/avatars/201709/21/
  14. $upload_path = public_path() . '/' . $folder_name;
  15. // 获取文件的后缀名,因图片从剪贴板里黏贴时后缀名为空,所以此处确保后缀一直存在
  16. $extension = strtolower($file->getClientOriginalExtension()) ?: 'png';
  17. // 拼接文件名,加前缀是为了增加辨析度,前缀可以是相关数据模型的 ID
  18. // 值如:1_1493521050_7BVc9v9ujP.png
  19. $filename = $file_prefix . '_' . time() . '_' . str_random(10) . '.' . $extension;
  20. // 如果上传的不是图片将终止操作
  21. if ( ! in_array($extension, $this->allowed_ext)) {
  22. return false;
  23. }
  24. // 将图片移动到我们的目标存储路径中
  25. $file->move($upload_path, $filename);
  26. // 如果限制了图片宽度,就进行裁剪
  27. if ($max_width && $extension != 'gif') {
  28. // 此类中封装的函数,用于裁剪图片
  29. $this->reduceSize($upload_path . '/' . $filename, $max_width);
  30. }
  31. return [
  32. 'path' => config('app.url') . "/$folder_name/$filename"
  33. ];
  34. }
  35. public function reduceSize($file_path, $max_width)
  36. {
  37. // 先实例化,传参是文件的磁盘物理路径
  38. $image = Image::make($file_path);
  39. // 进行大小调整的操作
  40. $image->resize($max_width, null, function ($constraint) {
  41. // 设定宽度是 $max_width,高度等比例双方缩放
  42. $constraint->aspectRatio();
  43. // 防止裁图时图片尺寸变大
  44. $constraint->upsize();
  45. });
  46. // 对图片修改后进行保存
  47. $image->save();
  48. }
  49. }

注:ImageUploadHandler 文件中的代码讲解请参考代码注释,此次新增 reduceSize() 方法,以及此方法的调用。

以上的 save() 方法中,我们新增了 $max_width 参数,用来指定最大图片宽度,我们修改 UsersController 的 update() 方法中的调用,修改为:

控制器调用

  1. public function update(UserRequest $request,ImageUploadHandler $uploader, User $user)
  2. {
  3. if ($request->avatar) {
  4. $result = $uploader->save($request->avatar, 'avatars', $user->id,362);
  5. if ($result) {
  6. $data['avatar'] = $result['path'];
  7. }
  8. }
  9. $user->update($data);
  10. return redirect()->route('users.show', $user->id)->with('success', '个人资料更新成功!');
  11. }

发表评论

表情:
评论列表 (有 0 条评论,443人围观)

还没有评论,来说两句吧...

相关阅读

    相关 laravel简单图片

    1. 先获取传过来的图片 2.可以选择打印一下 3.获取表的后缀 4.返回上传文件的扩展名称 5.给图片一个时间+随机数 6.创建图片目录 public f

    相关 laravel使用layui进行图片

           图片上传很多开发者都会遇到过,而一般为了用户体验性,我们图片上传都会做成无刷新提交,而最简单的是表单提交,但是用户体验性差,本篇博客就给大家介绍利用第三方插件[l