Загрузка и просмотр изображения с помощью MySQL и php

#php #mysql #upload #image

#php #mysql #загрузка #изображение

Вопрос:

Хорошо, у меня возникли проблемы с загрузкой и просмотром изображения, которое я пытаюсь использовать в качестве «изображений профиля», Когда я загружаю изображение, я не получаю никаких ошибок или чего-либо еще, но когда я перешел на страницу сведений, чтобы посмотреть, там ли оно, там ничего нет, phpmyadmin изменяет imagedata для BLOB — NULL на BLOB — 0B, так что что-то происходит, но все остальные атрибуты пусты, т. Е. имя изображения, imagetype, imagesize. Не публикуя весь мой код, потому что его довольно много, есть ли у кого-нибудь идеи о том, что это могло бы быть?

РЕДАКТИРОВАНИЕ С ПОМОЩЬЮ КОДА:

html для добавления:

 <tr><td>Profile Picture:</td> <td><input type="hidden" value="1000000" name="MAX_FILE_SIZE">
<input type="file" size="30" value="Image file" name="imagefile"></td></tr>
  

php для добавления:

 $profilepic = $_FILES['imagefile'];
$personid = add_person($username, $firstname, $lastname, $profilepic...etc);
  

воспроизведение изображения:

 <img src="get_image.php?id={$person.id}" {$person.imagesize} alt="{$person.imagename}">
  

в моем add_person у меня есть:

 $image_details = process_uploaded_image_file($profilepic);
list($imagedata, $imagename, $imagetype, $imagewidthheight) = $image_details;
then i insert those into my database
  

и, наконец, мой get_image.php

 $id = $_GET['id'];

$image = getImage($id);

$data = $image['imagedata'];
$name = $image['imagename'];
$type = $image['imagetype'];
$size = strlen($data);

header("Content-length: $size");
header("Content-type: $type");
header("Content-Disposition: attachment; filename=$name");
echo $data;
  

это все, что я могу опубликовать без функции обработки изображения и изменения размера и т.д.

РЕДАКТИРОВАНИЕ С ПОМОЩЬЮ process_ipload_image_file:

 function process_uploaded_image_file($image) {
// Check upload succeeded
if (!is_uploaded_file($image['tmp_name']) || $image['size'] == 0) {
  return NULL;
} 

// Extract details
$imagedata = addslashes(file_get_contents($image['tmp_name']));
$imagename = addslashes(basename($image['name']));
$imagesize = getimagesize($image['tmp_name']); // an array
$imagewidthheight = addslashes($imagesize[3]); 
$imagetype = $imagesize['mime'];

// Check file is a JPEG
if ($imagetype != "image/jpeg") {
  return NULL;
}

/*
echo "Before resizing: name = $imagename, type = $imagetype, ", 
   "size = '$imagewidthheight'<br>n";
*/

// Resize uploaded JPEG file, if necessary
// (shouldn't reuse name tmp.jpg repeatedly)
if ($imagesize[0] > MAX_WIDTH || $imagesize[1] > MAX_HEIGHT) {

    resize_image_file($image['tmp_name'], "images/tmp.jpg", 
                      MAX_WIDTH, MAX_HEIGHT);
  list($width,$height) = getimagesize("images/tmp.jpg");
  $imagedata = addslashes(file_get_contents("images/tmp.jpg"));
  $imagewidthheight = "width="$width" height="$height"";
}

/*
echo "After resizing: name = $imagename, type = $imagetype, ", 
     "size = '$imagewidthheight'<br>n";
*/

return array($imagedata, $imagename, $imagetype, $imagewidthheight);
}
  

Вот функция изменения размера

 /* Resize image into a width-height rectangle using GD library. */
function resize_image_file($src_file, $dst_file, $width, $height) {
// Compute new dimensions
list($width_orig, $height_orig) = getimagesize($src_file);

 $ratio_orig = $width_orig/$height_orig;

if ($width/$height > $ratio_orig) {
   $width = $height*$ratio_orig;
} else {
   $height = $width/$ratio_orig;
}

// Resample $srcfile
$image_p = imagecreatetruecolor($width, $height);
$image = imagecreatefromjpeg($src_file);
imagecopyresampled($image_p, $image, 0, 0, 0, 0, $width, $height, $width_orig, $height_orig);

// Output resized image to $dst_file
imagejpeg($image_p, "$dst_file", 100);
}
  

Комментарии:

1. опубликуйте основной код, который обрабатывает загрузку, трудно угадать.

2. трудно указать на проблему без набора фрагментов кода

3. Основываясь на этом коде, мне придется использовать функцию process_uploaded_image_file в качестве виновника.

4. Пожалуйста, опубликуйте полный код process_uploaded_image_file

5. хорошо, я отредактировал свой пост, чтобы включить их

Ответ №1:

 $imagedata = chunk_split(base64_encode(file_get_contents($image['tmp_name'])));
  

Комментарии:

1. О, и используйте base64_decode() при извлечении изображения из базы данных. т.е. base64_decode($row[‘image’])