用户上传的图片,经常都会超过几M,在小程序中展示时,加载会非常缓慢,影响用户体验,要用户自己ps图片再上传也麻烦,现在通过安装think-image(tp5)来对用户在后台上传图片时,进行自动压缩处理
首先在宝塔网站根目下运行安装(安装的过程,遇到种种错误,耐心在百度查找对应的答案)
可以使用宝塔网站自带的composer来运行,使用root权限
composer require topthink/think-image
安装好后,在fastadmin中有免费的插件可以自动压缩,但功能和判断比较少,所以不用它,自己修改源码,方法如下
2、找到公共上传类,application/common/library/Upload.php,在最下面添加一个方法,这里呢我是直接处理上传完成的图片,将其直接压缩覆盖原图
/**
* 等比压缩上传的图片,覆盖原图
* @Author: ELK
* @Date: 2023-3-27 01:00:28
* @param array $params 上传图片信息
* @param int $ratio 压缩比例,图片大于300K才进行压缩,先判断是横图,还是坚图,设置图片宽最大810,高最大540,做出相对应的比例压缩
*/
public function thumb_image(&$params,$ratio = 10)
{
//图片大于300K才进行压缩,先判断是横图,还是坚图,设置图片宽最大810,高最大540,做出相对应的比例压缩
if($params['filesize']>300000){
//横图=宽比高大
if($params['imagewidth']>=$params['imageheight']){
if($params['imagewidth']>=810){
$width = 810;
$height = round($params['imageheight']/($params['imagewidth']/810));
}else{
$width = $params['imagewidth'];
$height = $params['imageheight'];
}
}else{//坚图=高比宽大
if($params['imageheight']>=540){
$height = 540;
$width = round($params['imagewidth']/($params['imageheight']/540));
}else{
$width = $params['imagewidth'];
$height = $params['imageheight'];
}
}
$pathname = $params['url'];
$file = $this->file;
$image = \think\Image::open($file);
$image->thumb($width, $height)->save('.' . $pathname);
$image_root_path = ROOT_PATH . '/public' . $pathname;
$params['imagewidth'] = $width;
$params['imageheight'] = $height;
$params['filesize'] = filesize($image_root_path);
}
}
找到里面的 upload() 方法,在文件上传完成,将要添加到attachment表的图片数据时进行等比压缩处理,大概是下图的位置,在箭头指向的位置插入我们添加的处理方法
![](https://img-blog.csdnimg.cn/img_convert/dd5c9b21425e92755819e1570291292c.png)
if (in_array($this->fileInfo['type'], ['image/gif', 'image/jpg', 'image/jpeg', 'image/bmp', 'image/png', 'image/webp']) || in_array($this->fileInfo['suffix'], ['gif', 'jpg', 'jpeg', 'bmp', 'png', 'webp'])) {
$this->thumb_image($params);
}
//把本地路径加上url,显示完全路径,方便小程序展示
$params['url'] = 'https://wxshop.shop'. $params['url'];
完成