还记得上次的代码:上次博客链接
这里的代码存在的最大问题是:使用的是GD2的库,这个库不知道为什么我做了unset之类的操作(几乎所有变量都在每次循环后unset,就差每句都加)之后内存还是会溢满(讲道理不知道为啥GD库是把所有的图片全读进来,而且还不释放)。然后到技术群问了问,大神们推荐了ImageMagick,搜了一下发现真是好。
不过!!!!配置问题真的很大啊!!!!特别是在windows下的配置,对于版本的匹配简直是要求太高了。
首先各种安装顺序要严格教程来:
1.先装ImageMagick本身程序(注意这个要和你的apache位数匹配,32位apache要装32位,一般来说,apache会和你的操作系统位数匹配的,不过如果你和我一样偷懒用的是appserv而且还下错了版本,导致你出现了跟我一样64位系统结果装的是32的一系列appserv的东西,那就比较悲剧),apache的编译是32位还是64位是phpinfo的输出为准,以下的位数都以phpinfo函数输出为准。
2.安装完ImageMagick之后按照教程检查下能否在当前用户cmd下输出convert信息(注意安装路径不能有空格)
3.安装ImageMagick的php扩展php_imagick.dll(下载可以到pecl去找,这里一定注意要和你的php版本和ImageMagick的版本匹配,同时还要和你的位数匹配),我大概测试了下,在我机器上,6.9.1的ImageMagick搭配的是php_ImageMagick3.4.0的扩展。
注意如果你跟我一样,中间出现了好几个换版本的情况(不断尝试嘛,没办法,一般来说,最高版本的ImageMagick用不了……),建议换版本采用如下顺序:
先卸载ImageMagick,然后安装一个你挑好的更低版本的ImageMagick,然后同样要检查convert命令。 之后,拖对应版本的php扩展到ext目录,重启apache,建议不要先换php扩展的版本再换ImageMagick的版本……如果你非要觉得是php扩展的版本问题,那么换了之后重启apache,如果没啥反应可能要重启PC。
最后贴上新的压缩图片的脚本:
$width){
$scale=$width/$height;宽高比
$new_width = ($width>600?600*$scale:$width)*0.9;///固定高度
$new_height =($height>600?600:$height)*0.9;
}
else if($width>=$height){
$scale=$height/$width;宽高比
$new_width = ($width>600?600:$width)*0.9;///固定宽度
$new_height =($height>600?600*$scale:$height)*0.9;
}
switch($type){
case 1:
$giftype=check_gifcartoon($imgsrc);
if($giftype){
header('Content-Type:image/gif');
$image_wp=imagecreatetruecolor($new_width, $new_height);
$image = imagecreatefromgif($imgsrc);
imagecopyresampled($image_wp, $image, 0, 0, 0, 0, $new_width, $new_height, $width, $height);
imagejpeg($image_wp, $imgdst,75);
//unlink($imgsrc);
imagedestroy($image_wp);
imagedestroy($imgsrc);
imagedestroy($image);
unset ($image);
unset ($image_wp);
}
break;
case 2:
header('Content-Type:image/jpeg');
$image_wp=imagecreatetruecolor($new_width, $new_height);
$image = imagecreatefromjpeg($imgsrc);
imagecopyresampled($image_wp, $image, 0, 0, 0, 0, $new_width, $new_height, $width, $height);
imagejpeg($image_wp, $imgdst,75);
//unlink($imgsrc);
imagedestroy($image_wp);
imagedestroy($imgsrc);
imagedestroy($image);
unset ($image);
unset ($image_wp);
break;
case 3:
header('Content-Type:image/png');
$image_wp=imagecreatetruecolor($new_width, $new_height);
$image = imagecreatefrompng($imgsrc);
imagecopyresampled($image_wp, $image, 0, 0, 0, 0, $new_width, $new_height, $width, $height);
imagejpeg($image_wp, $imgdst,75);
//unlink($imgsrc);
imagedestroy($image_wp);
imagedestroy($imgsrc);
imagedestroy($image);
unset ($image);
unset ($image_wp);
break;
}
}
function writeNewpic($old, $new) {///使用ImageMagick
$maxsize=600;
$image = new Imagick($old);
if($image->getImageHeight() <= $image->getImageWidth())
{
$image->resizeImage($maxsize,0,Imagick::FILTER_LANCZOS,1);
}
else
{
$image->resizeImage(0,$maxsize,Imagick::FILTER_LANCZOS,1);
}
$image->setImageCompression(Imagick::COMPRESSION_JPEG);
$image->setImageCompressionQuality(90);
$image->stripImage();
$image->writeImage($new);
$image->destroy();
}
/**
* desription 判断是否gif动画
* @param sting $image_file图片路径
* @return boolean t 是 f 否
*/
function check_gifcartoon($image_file){
$fp = fopen($image_file,'rb');
$image_head = fread($fp,1024);
fclose($fp);
return preg_match("/".chr(0x21).chr(0xff).chr(0x0b).'NETSCAPE2.0'."/",$image_head)?false:true;
}
/**
* desription 对文件路径中的图片进行压缩
* @param sting $image_file图片路径
* @return boolean t 是 f 否
*/
function compressPic($dir)
{
if (is_dir($dir)){
$filesnames = scandir($dir);
foreach ($filesnames as $name) {
if ($name == '.' || $name == '..') continue;
//echo $name."\n";
$oldname=$dir."\\".$name." ";
//echo $oldname;
if (is_file($oldname)) {
$bname=basename($name,".jpg");
echo $bname;
$new_name=dirname(dirname($oldname))."\\picturesx\\".$bname."x.jpg";
echo $new_name."\n";
writeNewpic($oldname, $new_name);
//image_png_size_add($oldname,$new_name);
echo "conpress:".$bname.".jpg";
}
}
}
}
fputs(STDOUT,"输入图片文件夹地址:");
$dir=trim(fgets(STDIN));
mkdir(dirname($dir)."\\picturesx");
compressPic($dir);
改造了一下,原因有两个:1.图片递归搜索交给其他同学来先行完成了,所以去掉了递归(因为之前怀疑内存无法释放是不是GD2无法处理递归)
2.使用新的ImageMagick的writeNewpic函数进行压缩,效率快很多。