ОсновноеRadiotalkПользовательское
Webserv24 - Панель управления хостингом
11   •   Посмотреть все темы

🔒 Исправление проблем в php5.3 и php5.4

 

363
Максим @Максим
Выкладывает решения проблем и ошибок возникшие при переносе сайта от версии php5.2 на версию php5.3 / php5.4

363
Максим @Максим
Движок - Joomla

Ошибка: Warning: Parameter 1 to modMainMenuHelper::buildXML() expected to be a reference
Не отображается главное меню
Решение:
Ищем файл: modules/mod_mainmenu/helper.php
Меняем это:
function buildXML(&$params)
на это:
function buildXML($params)

363
Максим @Максим
Fatal error: Cannot redeclare quoted_printable_encode() in C:\home\test.ru\www\index.php on line 60

Функция с именем quoted_printable_encode уже есть в PHP 5.3+ . Если Вы хотите написать свою заглушку для PHP ниже 5.3, тогда:


if (!function_exists('quoted_printable_encode')) {
function quoted_printable_encode(...) {
...
}
}

363
Максим @Максим
Warning: Parameter 3 to showItem() expected to be a reference, value given in /home/.../.../.../includes/Cache/Lite/Function.php on line 100

Исправление, меняем
1.
это: $result = call_user_func_array(array($class, $method), $arguments);
на это:$result = call_user_func_array(array($class, $method), &$arguments);

2.
это: $result = call_user_func_array(array($$object_123456789, $method), $arguments);
на это: $result = call_user_func_array(array($$object_123456789, $method), &$arguments);

3.
это: $result = call_user_func_array($target, $arguments);
на это: $result = call_user_func_array($target, &$arguments);

Еще одна распространенная ошибка
Warning: call_user_func_array() expects parameter 2 to be array, null given in /home/user/domain.ru/libraries/joomla/cache/cache.php on line 143
Warning: call_user_func_array() expects parameter 2 to be array, null given in /home/user/domain.ru/libraries/joomla/session/session.php on line 272
В обоих файлах исправляется одинакого:
это: if(call_user_func_array( array( trim($class), 'test' ), null))
на это: if(call_user_func_array( array( trim($class), 'test' ), array()))

Отредактировано Максим - 16.06.2013
363
Максим @Максим
сегодня столкнулся еще с такой ошибкой
движок joomla
компонент - Savant

Warning: Parameter 1 to Savant2_Plugin_ahrefreview::plugin() expected to be a reference, value given in /home/.../.../.../components/com_mtree/Savant2.php on line 1127

решение
идет в /components/com_mtree/Savant2/
там есть файлы с началом - Savant2_Plugin_***
открываем файл и находим параметр - function plugin( &$link, ............ )
удаляем символ &
и так пробегаем все файлы Savant2_Plugin_***

363
Максим @Максим
Заменяем ereg на preg_match

Теперь разработчики в срочном порядке исправляют свой код заменяя функции ereg, eregi, ereg_replace, ereg_replacei соответствующими PCRE аналогами, благо замена получилась довольно простой:

1. заменить ereg и eregi на preg_match, ereg_replace и ereg_replacei на preg_replace;
2. добавить // разделители в начало и конец регулярного выражения;
3. если POSIX функция кончается на i (eregi, ereg_replacei) то добавить i в конец регулярного выражения после разделителя.
4. заменить POSIX спецсимволы соответствуюущими PCRE аналогами: [:alnum:] - \w или [0-9a-z], [:digit:] - \d или [0-9], [:space:] - \s, [:alpha:] - [a-z]

примеры:

ereg('expression') -> preg_match('/expression/')

eregi('expression') -> preg_match('/expression/i')

eregi('^[[:alnum:]][a-z0-9_.-]*@[a-z0-9.-]+\.[a-z]{2,4}$') -> preg_match('/^[a-z0-9][a-z0-9_.-]*@[a-z0-9.-]+\.[a-z]{2,4}$/i')

eregi("/", $val) -> preg_match("/\//i", $val)
или лучше такой вариант:
eregi("/", $val) -> substr_count($val,"/")

eregi_replace('/filter/([0-9]+,[0-9]+,[0-9]+,[0-9]+,[0-9]+)', '', url::current()) -> preg_replace('/\/filter\/([0-9]+,[0-9]+,[0-9]+,[0-9]+,[0-9]+)/i', '', url::current())
eregi('finance/pincode', url::current()) -> preg_match('/finance\/code/i', url::current())

Отредактировано Максим - 11.02.2013
363
Максим @Максим
Deprecated: Function set_magic_quotes_runtime()

находим в вашем скрипте строку:
set_magic_quotes_runtime(0);

и заменяем её на:
ini_set("magic_quotes_runtime", 0);

363
Максим @Максим
Функция split() устарела.
Решение
вместо split напишите explode

6600
Александр @admiral
Ошибка Joomla 1.5 + на php 5.3:
Warning: Parameter 1 to JHTMLGrid::access() expected to be a reference, value given in /home/user/site.ru/libraries/joomla/html/html.php on line 87
Открываем файл libraries\joomla\html\html.php и начиная со строки 87 заменяем эту часть кода:
if (is_callable( array( $className, $func ) ))
{
$args = func_get_args();
array_shift( $args );
return call_user_func_array( array( $className, $func ), $args );
}
else
{
JError::raiseWarning( 0, $className.'::'.$func.' not supported.' );
return false;
}

На это:
if (is_callable( array( $className, $func ) ))
{
$temp = func_get_args();
array_shift( $temp );
$args = array();
foreach ($temp as $k => $v) {
$args[] = &$temp[$k];
}
return call_user_func_array( array( $className, $func ), $args );
}
else
{
JError::raiseWarning( 0, $className.'::'.$func.' not supported.' );
return false;
}

6600
Александр @admiral
Максим пишет:

Функция split() устарела.
Решение
вместо split напишите explode

Если в функции split() используются регулярные выражения, то можно попробовать заменить её на ********** а не на explode, в некоторых случаях помогает исправить ошибки

6600
Александр @admiral
Часто при установки старых скриптов на php5.3 можно увидить предупреждения начинающиеся с:
Deprecated: ...

Что такок депрекация читаем тут - **********
Самое простое решение это скрыть эти предупреждения в файле .htaccess, добавив где нибудь в верху этого файла пару строк:
php_flag display_errors off
php_flag log_errors off

Но такое решение может скрыть реальные ошибки, поэтому не забываем что отключаем и не всегда именно это решение может являться правильным, а устранение этих предупреждений иногда занимает достаточно много времени

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

363
Максим @Максим
joomla

Deprecated: Assigning the return value of new by reference is deprecated in /home/LOGIN/DOMAIN/lib/kernel.php on line 94

открывает файл в текстовом редакторе
находим строку 94
TClasses::$instances[$ClassName] = &new $ClassName ();
удаляем символ &

получается так
TClasses::$instances[$ClassName] = new $ClassName ();
сохраняем

PS это касается всех предупреждений типа Deprecated: Assigning the return value of new by reference is deprecated

Отредактировано Максим - 26.11.2012
6600
Александр @admiral
Избавляемся от сообщений вида:
1. Deprecated: Assigning the return value of new by reference is deprecated in /home/user/путь_до_файла.php on line 42
Ищем файл /home/user/путь_до_файла.php, строку в нем - on line 42 и удаляем в этой строку знак &

2. Deprecated: Function call_user_method() is deprecated in /home/user/путь_до_файла.php on line 101
Смотрим строку на которую выдается сообщение - on line 101 и заменяем в ней функцию call_user_method на аналогичную для php5.3 - call_user_func c соблюдением синтаксиса, например:
elseif($this->isAction(index)) call_user_method(index,$this);
заменяем на:
elseif($this->isAction(index)) call_user_func(array(&$this, index));
Тут перед первой переменной ($this) ставится &, переменная пишется впереди, параметр (index) должен быть после переменных

Еще один пример:
if($this->isAction($method_name)) $this->set($method_name,call_user_method($method_name,$this));
Заменяем на:
if($this->isAction($method_name)) $this->set($method_name,call_user_func(array(&$this, $method_name)));

363
Максим @Максим
Проблема с php 5.4


Strict Standards: Only variables should be assigned by reference in /home/логин/папка-домена/engine/aApplication.php on line 22

Решение

открываем engine/aApplication.php строки 22, 23, 24

$this->page =& Page::getInstance();
$this->user =& $this->page->getUser();
$this->cache =& Cache::getInstance();

удаляем &

Проблема в скриптах Magento

Находим файл: lib/Zend/Db/Select.php

ЗАМЕНЯЕМ:

$correlationName = current(array_keys($this->_parts[self::FROM]));
НА:

$arrayKeys = array_keys($this->_parts[self::FROM]);
$correlationName = current($arrayKeys);

363
Максим @Максим
Проблема php5.4

Fatal error: 'continue' operator with non-constant operand is no longer supported in /home/USER/DOMAIN.ru/wp-content/themes/ШАБЛОН/functions.php on line 67


Был

foreach( $_POST['extra'] as $key=>$value ){
if( empty($value) )
continue delete_post_meta($post_id, $key);

update_post_meta($post_id, $key, $value);
}

Исправляем

foreach( $_POST['extra'] as $key=>$value ){
if( empty($value) ) {delete_post_meta($post_id, $key); continue; }
update_post_meta($post_id, $key, $value);
}

6600
Александр @admiral
Проблема php5.4

Strict Standards: Declaration of JParameter::loadSetupFile() should be compatible with JRegistry::loadSetupFile() in /home/user/domain.ru/libraries/joomla/html/parameter.php on line 0

Находим в файле /home/user/domain.ru/libraries/joomla/html/parameter.php функцию function loadSetupFile и исправляем:
public function loadSetupFile($path)

на:
public function loadSetupFile($path=null)

7094
Dim @Render
Проблема php5.4

Плагин wp-pagenavi в cms Wordpress выдаёт ошибку:
Strict Standards: Declaration of PageNavi_Options_Page::validate() should be compatible with scbAdminPage::validate($new_data, $old_data) in /home/user/domain.ru/wp-content/plugins/wp-pagenavi/admin.php on line 0

в файле /home/user/domain.ru/wp-content/plugins/wp-pagenavi/admin.php
function validate( $options ) {

заменить на
function validate( $new_data, $old_data ) {
$options = wp_parse_args($new_data, $old_data);

7094
Dim @Render
Проблема php5.4

Ошибка в старых версиях DLE < 10.
Deprecated: mysql_escape_string(): This function is deprecated; use mysql_real_escape_string() instead. in /home/user/domain.ru/engine/classes/mysqli.class.php on line 162

Находим в файле строки
function safesql( $source )
{
if ($this->db_id) return mysqli_real_escape_string ($this->db_id, $source);
else return mysql_escape_string($source);
}

заменяем на

function safesql( $source )
{
if ($this->db_id) return mysqli_real_escape_string ($this->db_id, $source);
else return mysql_real_escape_string($source);
}

в случае если после замены появляется ошибка:
Warning: mysql_real_escape_string(): Access denied for user ''@'localhost' (using password: NO) in /home/user/domain.ru/engine/classes/mysqli.class.php on line 162 Warning: mysql_real_escape_string(): A link to the server could not be established in /home/user/domain.ru/engine/classes/mysqli.class.php on line 162

заменить тогда на
function safesql( $source ) {
if(!$this->db_id) $this->connect(DBUSER, DBPASS, DBNAME, DBHOST);

if ($this->db_id) return mysqli_real_escape_string ($this->db_id, $source);
else return addslashes($source);
}

363
Максим @Максим
Проблема php5.4

Fatal error: Call-time pass-by-reference has been removed in /home/user/domain.ru/plugins/content/jw_disqus/jw_disqus.php on line 40

Открываем файл /home/user/domain.ru/plugins/content/jw_disqus/jw_disqus.php находим строку 40
$this->onContentPrepare('com_content.article', &$row, &$params, $limitstart );
Удаляем символ &

$this->onContentPrepare('com_content.article', $row, $params, $limitstart );


В закрытой теме нельзя отправлять сообщения.