Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779

Перевод скриптов версии php 5.2 под 7.2

04.08.2020, 12:47. Показов 1658. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет, скажите есть онлай сервесы или конвертеры что я мог туда скопировать пхп код написаный под версиб интерпритатора php 5.2, а мне его конвертонуло в версию 7.2?

Или хотябы показывало где в какой строке ошибки!

Просто есть очень много файлов под версию 5.2 и нужно это переделать под 7.2, какие есть варианты сделать это своими силами.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.08.2020, 12:47
Ответы с готовыми решениями:

Права доступа скриптов, выполняемых из-под PHP+Apache
Из консоли по ssh захожу из-под myusername и выполняю: #cd /var/www/myusername/data/www/mysitename/tmp ...

Перевод класса под PHP 7
Добрый Вечер! У меня проблема с переводом класса который осуществляет действия с БД и кешем, под версию php 7 выдает очень много ошибок,...

Выполнение скриптов shell из-под приложения
доброго времени суток. Подскажите, как прикрутить к событию onClick выполнение скрипта? есть некоторые удобные наработки скриптов, но через...

14
 Аватар для koders
259 / 193 / 50
Регистрация: 15.07.2016
Сообщений: 649
04.08.2020, 14:39
Показывать ошибки пых и сам может, без всяческих ненужных сторонних сервисов:
https://www.php.net/display-errors
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
04.08.2020, 21:47  [ТС]
добавил и тель выводит ошибки

ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);


________________________________________ ________


есть такая вот ошибка

Deprecated: Methods with the same name as their class will not be constructors in a future version of PHP; SQLclass has a deprecated constructor in /var/www/sergios/data/www/6/includes/sql.class.inc on line 2


PHP
1
2
3
4
5
6
7
function SQLclass( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = @mysql_connect( $this->_host, $this->_user, $this->_password );
    }

что не так и почему не работает функция под 7.2 версия.

Добавлено через 8 минут
так же вот такой код неработает

PHP
1
2
3
4
5
6
7
8
$mysql_host = 'localhost';                      // хост базы mysql
$mysql_base = 'sergo';                  // им¤ базы mysql
$mysql_user = 'root';                           // пользователь базы mysql
$mysql_pass = 'root';                           // пароль базы mysql
$var['base_tab_prefix'] = 'ram_';           // префикс таблиц MySQL
 
$base = new SQLclass($mysql_host, $mysql_base, $mysql_user, $mysql_pass);
$base->exec('set names cp1251');
0
 Аватар для sash23
563 / 410 / 259
Регистрация: 31.05.2016
Сообщений: 1,105
04.08.2020, 22:10
Цитата Сообщение от serauto79 Посмотреть сообщение
что не так и почему не работает функция под 7.2 версия.
так написано же почему. конструктор класса должен иметь имя __construct()
кроме того, у тебя используется расширение mysql которое уже давно выпилено из php. придется переписывать на mysqli или pdo.
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
04.08.2020, 23:09  [ТС]
ну с функцией mysql_connect() то понятно и просто
заменить на mysqli_connect()


а вот что вы имееете в ввиду под имя __construct()
покажите на примере!

PHP
1
2
3
4
5
6
7
function SQLclass( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = @mysql_connect( $this->_host, $this->_user, $this->_password );
    }
0
 Аватар для sash23
563 / 410 / 259
Регистрация: 31.05.2016
Сообщений: 1,105
04.08.2020, 23:14
function SQLclass заменить на function __construct с теми же аргументами.
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
08.08.2020, 19:07  [ТС]
Скажите что не так с этим кодом, я его уже подправил под версию пхп 7.2

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<?
class SQLclass {
    function __construct( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = @mysqli_connect( $this->_host, $this->_user, $this->_password );
    }
 
    #-- записи в массив состоящий из ассоциативных массивов записей
    function exec( $query, $nofetch=false ) {
        @mysqli_select_db( $this->_database, $this->_dbc );
        $qry = @mysqli_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (@mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_array($qry)) $ret[]=$row;
        }
        @mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив просых нумерованных массивов
    function exec_ar( $query, $nofetch=false ) {
        mysqli_select_db( $this->_database, $this->_dbc );
        $qry = mysqli_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_row($qry)) $ret[]=$row;
        }
        @mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив объектов
    function exec_obj( $query, $nofetch=false ) {
        mysqli_select_db( $this->_database, $this->_dbc );
        $qry = mysqli_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_object($qry)) $ret[]=$row;
        }
        @mysqli_free_result($qry);
        return $ret;
    }
 
    #-- закрыть соединение с базой
    function close() {
        mysqli_select_db( $this->_database, $this->_dbc );
        mysqli_close( $this->_dbc );
    }
 
    #-- id последней добавленной записи
    function new_id() {
        return mysqli_insert_id( $this->_dbc );
    }
 
    #-- затронуто записей последним запросом
    function affected() {
        return mysqli_affected_rows( $this->_dbc );
    }
 
}
?>


но чето с базой не соеденяет.







вот такой вариант кода под версию 5.2 работает


PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
<?
class SQLclass {
    #-- Constructor
    function SQLclass( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = @mysql_connect( $this->_host, $this->_user, $this->_password );
    }
 
    #-- записи в массив состоящий из ассоциативных массивов записей
    function exec( $query, $nofetch=false ) {
        @mysql_select_db( $this->_database, $this->_dbc );
        $qry = @mysql_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (@mysql_num_rows($qry)>0) while ($row=mysql_fetch_array($qry)) $ret[]=$row;
        }
        @mysql_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив просых нумерованных массивов
    function exec_ar( $query, $nofetch=false ) {
        mysql_select_db( $this->_database, $this->_dbc );
        $qry = mysql_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysql_num_rows($qry)>0) while ($row=mysql_fetch_row($qry)) $ret[]=$row;
        }
        @mysql_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив объектов
    function exec_obj( $query, $nofetch=false ) {
        mysql_select_db( $this->_database, $this->_dbc );
        $qry = mysql_query( $query, $this->_dbc );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysql_num_rows($qry)>0) while ($row=mysql_fetch_object($qry)) $ret[]=$row;
        }
        @mysql_free_result($qry);
        return $ret;
    }
 
    #-- закрыть соединение с базой
    function close() {
        mysql_select_db( $this->_database, $this->_dbc );
        mysql_close( $this->_dbc );
    }
 
    #-- id последней добавленной записи
    function new_id() {
        return mysql_insert_id( $this->_dbc );
    }
 
    #-- затронуто записей последним запросом
    function affected() {
        return mysql_affected_rows( $this->_dbc );
    }
 
}
?>
0
 Аватар для sash23
563 / 410 / 259
Регистрация: 31.05.2016
Сообщений: 1,105
09.08.2020, 15:45
Для начала уберите везде @.
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
09.08.2020, 16:21
и включите вывод ошибок.

Цитата Сообщение от serauto79 Посмотреть сообщение
ну с функцией mysql_connect() то понятно и просто
заменить на mysqli_connect()
неа, не на столько всё просто.

1. в mysqli_connect можно четвёртым параметром базу воткнуть.
2. раз уж вы решили использовать mysqli_select_db, то первым параметром идет объект подключения а вторым база.
3. во все последующие запросы, первым параметром идёт объект подключения а потом сам запрос.
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
09.08.2020, 21:49  [ТС]
Спасибо вам за ответы, вот сейчас так скрипт подправил, поставил вывод ошибок...

вот они

_____________

Notice: Object of class mysqli_result could not be converted to int in on line 16
Warning: mysqli_free_result() expects parameter 1 to be mysqli_result, boolean given in on line 19
_____________


PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<?
class SQLclass {
    function __construct( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = mysqli_connect( $this->_host, $this->_user, $this->_password, $this->_database );
    }
 
    #-- записи в массив состоящий из ассоциативных массивов записей
    function exec( $query, $nofetch=false ) {
        mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_array($qry)) $ret[]=$row;
        }
        mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив просых нумерованных массивов
    function exec_ar( $query, $nofetch=false ) {
        mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_row($qry)) $ret[]=$row;
        }
        mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив объектов
    function exec_obj( $query, $nofetch=false ) {
        mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_object($qry)) $ret[]=$row;
        }
        mysqli_free_result($qry);
        return $ret;
    }
 
    #-- закрыть соединение с базой
    function close() {
        mysqli_select_db( $this->_dbc, $this->_database );
        mysqli_close( $this->_dbc );
    }
 
    #-- id последней добавленной записи
    function new_id() {
        return mysqli_insert_id( $this->_dbc );
    }
 
    #-- затронуто записей последним запросом
    function affected() {
        return mysqli_affected_rows( $this->_dbc );
    }
 
}
?>

Подскажите как пофиксить их, спасибо.
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
09.08.2020, 22:10
PHP
1
2
3
if ($qry>0 && $nofetch==false) {
    if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_array($qry)) $ret[]=$row;
}
поменять на это:
PHP
1
2
3
if (mysqli_num_rows($qry)>0 && $nofetch==false) {
    while ($row=mysqli_fetch_array($qry)) $ret[]=$row;
}
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
10.08.2020, 00:15  [ТС]
sasha0012
Поменял и теперь 2 ошибки в этом коде

Warning: mysqli_num_rows() expects parameter 1 to be mysqli_result, boolean given in on line 16
Warning: mysqli_free_result() expects parameter 1 to be mysqli_result, boolean given in on line 20
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
10.08.2020, 08:34
serauto79, mysqli_query сработал с ошибкой. Смотрите что попадает в $query. И mysql тоже может показать ошибки:
PHP
1
2
3
4
5
$qry = mysqli_query( $this->_dbc, $query );
$error = mysqli_error($this->_dbc);
if($error){
   return $error;
}
и раз вы базу указали в mysqli_connect, то уберите это: mysqli_select_db( $this->_dbc, $this->_database );
0
21 / 10 / 4
Регистрация: 02.04.2015
Сообщений: 779
10.08.2020, 10:45  [ТС]
Отредактировал как вы сказали

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?
class SQLclass {
    function __construct( $host, $database, $user, $password ) {
        $this->_database = $database;
        $this->_host     = $host;
        $this->_user     = $user;
        $this->_password = $password;
        $this->_dbc      = mysqli_connect( $this->_host, $this->_user, $this->_password, $this->_database );
    }
 
 
    #-- записи в массив состоящий из ассоциативных массивов записей
    function exec( $query, $nofetch=false ) {
        #-- mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if (mysqli_num_rows($qry)>0 && $nofetch==false) {
        while ($row=mysqli_fetch_array($qry)) $ret[]=$row;
        }
        
        mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив просых нумерованных массивов
    function exec_ar( $query, $nofetch=false ) {
        #-- mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_row($qry)) $ret[]=$row;
        }
        mysqli_free_result($qry);
        return $ret;
    }
 
    #-- записи в массив объектов
    function exec_obj( $query, $nofetch=false ) {
        #-- mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $ret = array();
        if ($qry>0 && $nofetch==false) {
         if (mysqli_num_rows($qry)>0) while ($row=mysqli_fetch_object($qry)) $ret[]=$row;
        }
        mysqli_free_result($qry);
        return $ret;
    }
    
    
$qry = mysqli_query( $this->_dbc, $query );
$error = mysqli_error($this->_dbc);
if($error){
return $error;
}
 
 
    #-- закрыть соединение с базой
    function close() {
        #-- mysqli_select_db( $this->_dbc, $this->_database );
        mysqli_close( $this->_dbc );
    }
 
    #-- id последней добавленной записи
    function new_id() {
        return mysqli_insert_id( $this->_dbc );
    }
 
    #-- затронуто записей последним запросом
    function affected() {
        return mysqli_affected_rows( $this->_dbc );
    }
 
}
?>

ОШИБКА!

Parse error: syntax error, unexpected '$qry' (T_VARIABLE), expecting function (T_FUNCTION) or const (T_CONST) in on line 50
0
1152 / 554 / 320
Регистрация: 21.06.2012
Сообщений: 1,854
10.08.2020, 10:58
Это такой прикол, да? Подумал подшутить и сказать вам что этот код надо в файл со стилями поставить, но потом подумал что не стоит.

serauto79, везде где у вас стоит это: #-- mysqli_select_db( $this->_dbc, $this->_database ); а под ним это: $qry = mysqli_query( $this->_dbc, $query );, то вот под это: $qry = mysqli_query( $this->_dbc, $query ); ставите это:
PHP
1
2
3
4
$error = mysqli_error($this->_dbc);
if($error){
return $error;
}
В итоге должно получиться вот это:
PHP
1
2
3
4
5
6
        #-- mysqli_select_db( $this->_dbc, $this->_database );
        $qry = mysqli_query( $this->_dbc, $query );
        $error = mysqli_error($this->_dbc);
        if($error){
             return $error;
        }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.08.2020, 10:58
Помогаю со студенческими работами здесь

Написание скриптов на ASP под Windows Me
У меня Windows Me. Могу ли я писать скрипты на ASP?

Отладка PHP скриптов
Здраствуйте! Интересуют меня программы(для виндовс)для отладки php скриптов. В частности возможность выполнение скриптов по меткам(как...

Подключение JS-скриптов в PHP
Добрый день! Отправляю ajax-запрос к php файлу и передаю название js-файла, который необходимо будет подключить. Сервер выдает 500 ошибку ...

Кэширование PHP скриптов?
Здравствуйте уважаемые программисты, я не программист в настоящее время выбираю CMS на PHP, для увеличения производительности хочу...

Прикрепление php-скриптов
Досконально описываю то, что не понимаю=) Есть хостинг. С поддержкой PHP и Мускла Есть страничка html Есть несколько ПХП скриптов,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru