ImageUploadHandler.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. namespace App\Handlers;
  3. use Image;
  4. use Illuminate\Support\Facades\Storage;
  5. class ImageUploadHandler
  6. {
  7. protected $allowed_ext = ["png", "jpg", "gif", 'jpeg'];
  8. /**
  9. * 保存图片到本地
  10. * @param $file
  11. * @param $folder
  12. * @param $file_prefix
  13. * @param bool $max_width
  14. * @return array|bool
  15. */
  16. public function save($file, $folder, $file_prefix, $max_width = false)
  17. {
  18. // 构建存储的文件夹规则,值如:uploads/images/avatars/201709/21/
  19. // 文件夹切割能让查找效率更高。
  20. $folder_name = $folder_qiniu = "uploads/images/$folder/" . date("Ym", time()) . '/'.date("d", time()).'/';
  21. // 文件具体存储的物理路径,`public_path()` 获取的是 `public` 文件夹的物理路径。
  22. // 值如:/home/vagrant/Code/larabbs/public/uploads/images/avatars/201709/21/
  23. $upload_path = public_path() . '/' . $folder_name;
  24. // 获取文件的后缀名,因图片从剪贴板里黏贴时后缀名为空,所以此处确保后缀一直存在
  25. $extension = strtolower($file->getClientOriginalExtension()) ?: 'png';
  26. // 拼接文件名,加前缀是为了增加辨析度,前缀可以是相关数据模型的 ID
  27. // 值如:1_1493521050_7BVc9v9ujP.png
  28. $filename = $file_prefix . '_' . time() . '_' . str_random(10) . '.' . $extension;
  29. // 如果上传的不是图片将终止操作
  30. if ( ! in_array($extension, $this->allowed_ext)) {
  31. return false;
  32. }
  33. // 将图片移动到我们的目标存储路径中
  34. $file->move($upload_path, $filename);
  35. // 如果是本地就存储到磁盘, 否则存储到 七牛云
  36. if (app()->isLocal()){
  37. // 如果限制了图片宽度,就进行裁剪
  38. if ($max_width && $extension != 'gif') {
  39. // 此类中封装的函数,用于裁剪图片
  40. $this->reduseSize($upload_path . $filename, $max_width);
  41. }
  42. } else {
  43. // 将图片上传至七牛云空间
  44. $qiniu = Storage::disk('qiniu');
  45. $qiniu->write($folder_qiniu . $filename, $upload_path . $filename);
  46. // 删除本地文件
  47. unlink($folder_qiniu . $filename);
  48. }
  49. return [
  50. 'path' => "/$folder_name$filename"
  51. ];
  52. }
  53. public function update($path, $file)
  54. {
  55. $path_path = substr($path, 0, strrpos($path, '.'));
  56. $path_filename = substr($path_path, strrpos($path_path, '/') + 1);
  57. $path_path = substr($path_path, 0, strrpos($path_path, '/'));
  58. // 获取文件的后缀名,因图片从剪贴板里黏贴时后缀名为空,所以此处确保后缀一直存在
  59. $extension = strtolower($file->getClientOriginalExtension()) ?: 'png';
  60. // 拼接文件名,加前缀是为了增加辨析度,前缀可以是相关数据模型的 ID
  61. // 值如:1_1493521050_7BVc9v9ujP.png
  62. $filename = $path_filename . '.' . $extension;
  63. $upload_path = public_path() . '/' . $path_path .'/';
  64. // 如果上传的不是图片将终止操作
  65. if ( ! in_array($extension, $this->allowed_ext)) {
  66. return false;
  67. }
  68. // 将图片移动到我们的目标存储路径中
  69. $file->move($upload_path, $filename);
  70. $qiniu = Storage::disk('qiniu');
  71. $qiniu->update($path, $upload_path . $filename);
  72. }
  73. public function delete($path)
  74. {
  75. $qiniu = Storage::disk('qiniu');
  76. $qiniu->delete($path);
  77. }
  78. /**
  79. * 图片裁剪
  80. * @param $file_path
  81. * @param $max_width
  82. */
  83. public function reduseSize($file_path, $max_width)
  84. {
  85. // 先实例化,传参是文件的磁盘物理路径
  86. $image = Image::make($file_path);
  87. // 进行大小调整的操作
  88. $image->resize($max_width, null, function ($constraint) {
  89. // 设定宽度是 $max_width,高度等比例双方缩放
  90. $constraint->aspectRatio();
  91. // 防止裁图时图片尺寸变大
  92. $constraint->upsize();
  93. });
  94. // 对图片修改后进行保存
  95. $image->save();
  96. }
  97. }