我有一个程序,其图像存储为 MySQL 数据库中的 blob,除了我的下载链接外,它运行良好。它按应有的方式下载,并且大小也合适,但图像不显示。
上传时,这主要是图像的处理方式:
$image = $_FILES['image']['tmp_name'];
$data = file_get_contents($image);
然后我将 PDO 用于 MySQL 连接:
$q->bindParam(2, $data, PDO::PARAM_LOB);
这在使用 base64 时工作正常。
$image = new Gmagick();
$image->readimageblob($data);
<img src="data:image/'.$ext.';base64,'.base64_encode($image->getimageblob()).'" />';
但这是我的问题。
header('Content-Disposition: attachment; filename='.$regnr.'-'.$id.'.'.$ext;
header("Content-type: image/$ext");
header("Content-length: $size");
echo $data;
我也试过 echo $image->getimageblob();等等......以及其他一些标题。但结果是一样的,图像下载,是正确的大小和格式,但我无法阅读。
我该如何解决这个问题?
最佳答案
我找到了答案。我想我用了大约 15 个小时。
虽然,如果有人想知道,解决方案是一条简单的线:
ob_clean();
输出前。
关于下载时图像 blob 不可读(php),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13231891/