exec

(PHP 3, PHP 4 , PHP 5)

exec -- Execute an external program

Description

string exec ( string command [, array &output [, int &return_var]])

exec() executes the given command, however it does not output anything. It simply returns the last line from the result of the command. If you need to execute a command and have all the data from the command passed directly back without any interference, use the passthru() function.

If the output argument is present, then the specified array will be filled with every line of output from the command. Line endings, such as \n, are not included in this array. Note that if the array already contains some elements, exec() will append to the end of the array. If you do not want the function to append elements, call unset() on the array before passing it to exec().

If the return_var argument is present along with the output argument, then the return status of the executed command will be written to this variable.

Eksempel 1. An exec() example

<?php
// outputs the username that owns the running php/httpd process
// (on a system with the "whoami" executable in the path)
echo exec('whoami');
?>

Advarsel

Hvis du vil tillade data fra bruger input til at blive viderebragt til denne funktion, så bør du bruge escapeshellarg() eller escapeshellcmd() til at sikre at brugere ikke kan snyde systemmet til at eksekvere fjendtlige kommandoer.

Bemærk: Hvis du starter et program ved brug af denne funktion og ønsker at lade det køre i baggrunden, skal du sørge for at outputtet fra det program er redirected til en fil eller en anden output stream, ellers vil hænge indtil udførelsen af programmet er færdig.

Bemærk: Når safe mode er aktiveret, kan du kun eksekvere eksekverbare filer inden for safe_mode_exec_dir. Af praktiske årsager er det pt. ikke tilladet at have .. komponenter i stien til den eksekverbare fil.

Advarsel

Med safe mode aktiveret, vil alle ord efterfølgende den oprindelige kommandostreng blive behandlet som et enkelt argument. Derfor, echo y | echo x bliver echo "y | echo x".

See also system(), passthru(), popen(), escapeshellcmd() pcntl_exec(), and the backtick operator.