Я пытаюсь отобразить изображение, сохраненное в столбце BLOB в базе данных;
Я извлекаю данные из базы данных с помощью SELECT, не выполняю преобразований данных и отображаю их со следующим (из script, единственным выходом которого является следующий):
header("Content-Type: image/jpeg");
echo $image;
Обратите внимание, что хром отображает размер содержимого как правильный размер для изображения, а также правильный тип mime (image/jpeg
). ничто не повторяет перед заголовком, а ive проверяет правильность блоба в базе данных. Также нет теневых пробелов до или после тегов <?php ?>
.
chrome/IE отображает значок изображения, но не сам образ. любые идеи?
EDIT: изображение получает из базы данных как таковое:
$sql = "SELECT * FROM products WHERE id = $id";
$sth = $db->query($sql);
$row = $sth->fetch();
$image = $row['image'];
var_dump ($ image) дает:
string 'ÿØÿà�JFIF��x�x��ÿá�ZExif��MM�*�����������J��������Q�������Q������tQ������t�����† ��±ÿÛ�C�
ÿÛ�CÿÀ�_"�ÿÄ�����������
ÿÄ�µ���}�!1AQa"q2‘¡#B±ÁRÑð$3br‚
%&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyzƒ„…†‡ˆ‰Š’""•–—˜™š¢£¤¥¦§¨©ª²³ ´µ¶·¸¹ºÂÃÄÅÆÇÈÉÊÒÓÔÕÖ×ØÙÚáâãäåæçèéêñòóôõö÷øùúÿÄ��������'... (length=60766)