system
(PHP 4, PHP 5, PHP 7)
system — Выполнить внешнюю программу и отобразить вывод
Описание
$command
, int &$result_code
= null
) : string|false
system() похожа на C-версию этой
функции в том, что она выполняет указанную команду
command
и выводит её результат.
Вызов функции system() также пытается автоматически очистить буфер вывода веб-сервера после каждой строки вывода, если PHP работает как модуль сервера.
Если вам нужно выполнить команду и получить все данные из команды непосредственно без каких-либо препятствий, используйте функцию passthru().
Список параметров
-
command
-
Команда, которая будет выполнена.
-
result_code
-
Если передан аргумент
result_code
, то в эту переменную будет записан код возврата выполненной команды.
Возвращаемые значения
Возвращает последнюю строку вывода команды в случае успеха, и false
- в случае неудачи.
Примеры
Пример #1 Пример использования system()
<?php
echo '<pre>';
// Выводит весь результат команды оболочки "ls" и возвращает
// последнюю строку вывода в переменной $last_line. Сохраняет код возврата
// команды в $retval.
$last_line = system('ls', $retval);
// Выводим дополнительную информацию
echo '
</pre>
<hr />Последняя строка вывода: ' . $last_line . '
<hr />Код возврата: ' . $retval;
?>
Примечания
Если вы собираетесь передавать функции пользовательские данные, используйте функции escapeshellarg() или escapeshellcmd() для того, чтобы пользователи не смогли обмануть систему, запустив произвольную команду.
Замечание:
Если вы собираетесь использовать эту функцию в программе, работающей в качестве демона, убедитесь, что стандартный вывод функции направлен в файл или другой поток, в противном случае PHP зависнет вплоть до конца выполнения программы.
Смотрите также
- exec() - Выполнить внешнюю программу
- passthru() - Выполнить внешнюю программу и отобразить необработанный вывод
- popen() - Открывает файловый указатель процесса
- escapeshellcmd() - Экранировать метасимволы командной строки
- pcntl_exec() - Запустить указанную программу в области текущего процесса
- Оператор исполнения