将blob保存到php中的图像文件

时间:2012-01-23 13:05:59

标签: php mysql

我的数据库中有一个图像保存为大型BLOB。现在我想检索它并将其保存到我的文件系统中。

为此目的,我已经完成了以下操作,但保存到我的文件系统的图像已损坏。

Approach1:

$basedir = 'images/';
$imagename = strtolower(preg_replace('/([^\w\d\-_]+)/', '-', $row->name));
$filename = $basedir . $imagename . '_' . $row->id. '.jpg';
$file_content = base64_decode($row->image_data);
return file_put_contents($filename, $file_content);

Approach2:

$basedir = 'images/';
$imagename = strtolower(preg_replace('/([^\w\d\-_]+)/', '-', $row->name));
$filename = $basedir . $imagename . '_' . $row->id . '.jpg';
fopen($filename,'w');
if($fh = fopen("{$filename}", "wb")) {
    fwrite($fh, base64_decode($row->image_data));
    fclose($fh) ;
}

请帮助!!!

1 个答案:

答案 0 :(得分:3)

如果BLOB未编码,这应该可以解决问题:

file_put_contents('filename.jpg', $row->image_data);