1

我有一个表单,用户可以将图像上传到我的 MySQL 数据库。该表包含三列idnameimageImage是具有默认设置的 blob 列。我能够存储图像数据,但是当我获取数据并尝试在网页上显示它时,我只是得到一个损坏的图像(在这种情况下它是一个 jpeg 文件)。

我怀疑某处的编码出了问题。我的 upload.php 文件以 UTF-8 编码,没有 BOM。这是我的上传代码:

$image = addslashes(file_get_contents($_FILES['image']['tmp_name']));
$image_name = addslashes($_FILES['image']['name']);

$insert = $conn->prepare('INSERT INTO images VALUES(:id,:name,:image)');
$insert->bindValue(':id', '');
$insert->bindParam(':name', $image_name);
$insert->bindParam(':image', $image);
$insert->execute();

这就是我尝试显示图像的地方。

$select = $conn->prepare('SELECT image FROM images WHERE id = 2');
$select->execute();

$display = $select->fetch();

echo '<img src="data:image/jpg;base64,' . base64_encode( $display['image'] ) . '" />';

我观看了有关 MySQL 中 blob 的视频教程,其中 blob 列具有binary属性。但是,当我尝试创建这样的列时,我收到错误 1064。我什至不知道它与此有什么关系。

4

1 回答 1

0

首先,您不应该使用addslashes()准备好的语句(这不是您的问题)。

默认情况下,->bindParam()默认为 type PDO::PARAM_STR,因此您需要指定您传递的数据不是字符串。

尝试:

$insert->bindParam(':image', $image, PDO::PARAM_LOB);

在数据库中存储二进制数据也会导致各种问题。我建议将文件存储到磁盘并将其路径存储在数据库中 - 它具有各种优势。

于 2013-04-18T21:58:42.233 回答