我有一个将图像存储在MySQL BLOB字段中的数据库。我设置了一个脚本,根据URL中的ID选择并显示图像,如果你附加?resize = 800x600,我也会这样做,它会调整图像大小(在这种情况下,为800x600)。
我使用的主机没有安装Imagemagick,也不允许我自己动手,所以我需要使用PHP的GD库来调整图像大小。
但是我还没有找到像Imagick的readImageBlob()
这样的函数,所以我不能编辑我从数据库中获得的二进制字符串,而不首先创建一个临时文件,编辑它,从中获取二进制字符串,发送它到浏览器,然后删除它(这是太多的步骤,特别是因为这将在它投入生产时获得几千次点击)。
所以我的问题是,有没有办法用PHP的GD复制readImageBlob
而无需通过临时文件解决方案?
答案 0 :(得分:5)
imagecreatefromstring()应该做到这一点。我认为手册中的功能示例几乎就是您所需要的:
$im = imagecreatefromstring($data);
if ($im !== false) {
header('Content-Type: image/png');
imagepng($im);
imagedestroy($im);
}
else {
echo 'An error occurred.';
}
其中$data
是数据库中的二进制数据字符串。