Перейти к содержанию
Xren

Предупреждение Array to string conversion в error.log

Рекомендуемые сообщения

Здравствуйте, постоянно появляется ошибка в error.log, пробовал гуглить и пытаться понять в чем дело, но так и не получилось  :

PHP Notice:  Array to string conversion in \catalog\model\tool\image.php on line 15

 

Собственно код данного файла (функция ресайз), начиная с 14 строчки :

public function resize($filename, $width, $height, $type = "") {
if (!file_exists(DIR_IMAGE . $filename) || !is_file(DIR_IMAGE . $filename)) {
return;
} 

$info = pathinfo($filename);

$extension = $info['extension'];

$old_image = $filename;
$new_image = 'cache/' . utf8_substr($filename, 0, utf8_strrpos($filename, '.')) . '-' . $width . 'x' . $height . $type .'.' . $extension;

if (!file_exists(DIR_IMAGE . $new_image) || (filemtime(DIR_IMAGE . $old_image) > filemtime(DIR_IMAGE . $new_image))) {
$path = '';

$directories = explode('/', dirname(str_replace('../', '', $new_image)));

foreach ($directories as $directory) {
$path = $path . '/' . $directory;

if (!file_exists(DIR_IMAGE . $path)) {
@mkdir(DIR_IMAGE . $path, 0777);
}
}

list($width_orig, $height_orig) = getimagesize(DIR_IMAGE . $old_image);

if ($width_orig != $width || $height_orig != $height) {
$image = new Image(DIR_IMAGE . $old_image);
$image->resize($width, $height, $type);
$image->save(DIR_IMAGE . $new_image);
} else {
copy(DIR_IMAGE . $old_image, DIR_IMAGE . $new_image);
}
}

return $this->getImageUrl($new_image);

} 

 Увы не в моих силах понять что же не так работает, поэтому прошу помощи знающих. 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

хелп, достали ошибки, не понимаю куда копать ...

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

у меня тоже такая проблема..

 

Знаю одно, если у товара два изображения эта ошибка пропадает.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

(предположительно) Такая ошибка может возникать, если передаваемый функции resize() параметр $filename не  строка, а массив.

 

Т.е. нужно смотреть код, предшествующий вызову функции resize().

 

Или перед строкой 15 временно добавьте строку отладочной печати 

echo serialize($filename);

и покажите результат ее работы здесь

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

(предположительно) Такая ошибка может возникать, если передаваемый функции resize() параметр $filename не  строка, а массив.

 

Т.е. нужно смотреть код, предшествующий вызову функции resize().

 

Или перед строкой 15 временно добавьте строку отладочной печати 

echo serialize($filename);

и покажите результат ее работы здесь

 

Это я заметил делает какой -то vqmod допил...  встречал не только в resize.

Аккуратнее с костылями vqmod, иногда кривые руки разработчиков подсовывают вот такие "сюрпризы". 

У себя в модуле поставил проверку где только можно из-за таких костылей

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.