PHP-如何实时处理图片?

PHP-如何实时处理图片?

清晨说ぺ晚安 发布于 2017-03-03 字数 548 浏览 1149 回复 3

发现google的图片可以被实时缩放:
如下面这个地址
https://lh4.ggpht.com/-Lymw9XVvZ_yKoYTLKt2P-zBBsDK35tXEopVX0rL89r8daWwQZDZjrvSggLOXzDyqPQ=w100

w100可以任意修改为w512大小以内的图片。给我感觉的是实时处理的。我也遇到这个问题,就是服务器上有一组图片,可是在不同的地方展示的大小不同,现在我们是提前生成n份图片缓存,如果能实时生成缓存,那么将大大提高我们的灵活度。

所以想请教大家:
1.google这么做是实时处理图片吗?
2.这么做的压力在正常情况下会大吗?
3.如何在中小的服务器上实现这个功能,而不带来太大的压力。

如果你对这篇文章有疑问,欢迎到本站 社区 发帖提问或使用手Q扫描下方二维码加群参与讨论,获取更多帮助。

扫码加入群聊

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

灵芸 2017-04-04 3 楼

这个可以是实时处理的,我们现在就是这么弄的,就是通过URL实时生成图片,并动态输出,然后由前端Squid缓存,而在用户访问的时候就直接走的缓存,如果缓存没有再由web实时生成图片,再进行缓存。这样服务器也不会有太大的压力。

虐人心 2017-03-10 2 楼

我想这个应该是即时生成的,但是 如果需要缓解服务器压力,可以做一个缓存。比如,有一个额很大的图片,当第一个用户访问带有参数w100的链接时,生成一个宽度100的缩略图。下次再有用户访问w100的链接,直接取第一次生成的图片即可

至于第一次生成缩略图,在php里也很容易实现,我常用的一段缩略图代码如下:

<?php
class resizeimage
{
//图片类型
var $type;
//实际宽度
var $width;
//实际高度
var $height;
//改变后的宽度
var $resize_width;
//改变后的高度
var $resize_height;
//是否裁图
var $cut;
//源图象
var $srcimg;
//目标图象地址
var $dstimg;
//临时创建的图象
var $im;

function resizeimage($img, $wid, $hei,$c,$dstpath)
{
$this->srcimg = $img;
$this->resize_width = $wid;
$this->resize_height = $hei;
$this->cut = $c;
//图片的类型

$this->type = strtolower(substr(strrchr($this->srcimg,"."),1));

//初始化图象
$this->initi_img();
//目标图象地址
$this -> dst_img($dstpath);
//--
$this->width = imagesx($this->im);
$this->height = imagesy($this->im);
//生成图象
$this->newimg();
ImageDestroy ($this->im);
}
function newimg()
{
//改变后的图象的比例
$resize_ratio = ($this->resize_width)/($this->resize_height);
//实际图象的比例
$ratio = ($this->width)/($this->height);
if(($this->cut)=="1")
//裁图
{
if($ratio>=$resize_ratio)
//高度优先
{
$newimg = imagecreatetruecolor($this->resize_width,$this->resize_height);
imagecopyresampled($newimg, $this->im, 0, 0, 0, 0, $this->resize_width,$this->resize_height, (($this->height)*$resize_ratio), $this->height);
ImageJpeg ($newimg,$this->dstimg);
}
if($ratio<$resize_ratio)
//宽度优先
{
$newimg = imagecreatetruecolor($this->resize_width,$this->resize_height);
imagecopyresampled($newimg, $this->im, 0, 0, 0, 0, $this->resize_width, $this->resize_height, $this->width, (($this->width)/$resize_ratio));
ImageJpeg ($newimg,$this->dstimg);
}
}
else
//不裁图
{
if($ratio>=$resize_ratio)
{
$newimg = imagecreatetruecolor($this->resize_width,($this->resize_width)/$ratio);
imagecopyresampled($newimg, $this->im, 0, 0, 0, 0, $this->resize_width, ($this->resize_width)/$ratio, $this->width, $this->height);
ImageJpeg ($newimg,$this->dstimg);
}
if($ratio<$resize_ratio)
{
$newimg = imagecreatetruecolor(($this->resize_height)*$ratio,$this->resize_height);
imagecopyresampled($newimg, $this->im, 0, 0, 0, 0, ($this->resize_height)*$ratio, $this->resize_height, $this->width, $this->height);
ImageJpeg ($newimg,$this->dstimg);
}
}
}
//初始化图象
function initi_img()
{
if($this->type=="jpg")
{
$this->im = imagecreatefromjpeg($this->srcimg);
}
if($this->type=="gif")
{
$this->im = imagecreatefromgif($this->srcimg);
}
if($this->type=="png")
{
$this->im = imagecreatefrompng($this->srcimg);
}
}
//图象目标地址
function dst_img($dstpath)
{
$full_length = strlen($this->srcimg);

$type_length = strlen($this->type);
$name_length = $full_length-$type_length;

$name = substr($this->srcimg,0,$name_length-1);
$this->dstimg = $dstpath;

//echo $this->dstimg;
}
}
?>

使用也很简单:

$resizeimage = new resizeimage("图片源文件地址", "200", "100", "0","缩略图地址");

只需要修改相应参数即可。

泛泛之交 2017-03-10 1 楼

是实时处理的,本质上是使用URL重写,将请求重定向到php文件,然后进行处理。

实时生成对于服务器的压力还是比较大的,尤其是是处理大图片的时候很吃CPU资源,如果想减轻服务器压力,那么第一次处理图片后可以选择生成缓存,第二次请求就不会有额外的资源开销。

这类需求的难点在于

如何保证缓存的唯一性,比如w100,h100和h100,w100对应的缓存应该为一张
如何设计一个简洁好用的API
大量图片文件生成时,如何以比较好的层次结构存储文件。

以上问题的解决,请参看我的开源项目 EvaCloudImage - 基于URL生成缩略图的轻量级PHP库.

在我的计划中EvaCloudImage下一步还增加一些功能,进一步减轻服务器压力提高性能,包括:

同步到云服务作为分流及备份
对于超大图片有限制
采用消息队列生成缓存