Operatori di esecuzione

PHP supporta un operatore di esecuzione: backticks (``). Si noti che non sono apostrofi o apici! PHP cercherà di eseguire il contenuto dei backticks come comando di shell; sarà restituito l'output (ovvero, non sarà semplicemente inviato all'output, ma potrà essere assegnato ad una variabile). L'uso dell'operatore backtick è identico alla funzione shell_exec().

= `ls -al`;


L'operatore backtick è disabilitato quando è disabilitata shell_exec().


Diversamente da altri linguaggi, i backtick non hanno un significato speciale all'interno di stringhe delimitate da doppi apici.

add a note add a note

User Contributed Notes 2 notes

16 years ago
Just a general usage note.  I had a very difficult time solving a problem with my script, when I accidentally put one of these backticks at the beginning of a line, like so:

[lots of code]
`    $URL = "blah...";
[more code]

Since the backtick is right above the tab key, I probably just fat-fingered it while indenting the code.

What made this so hard to find, was that PHP reported a parse error about 50 or so lines *below* the line containing the backtick.  (There were no other backticks anywhere in my code.)  And the error message was rather cryptic:

Parse error: parse error, expecting `T_STRING' or `T_VARIABLE' or `T_NUM_STRING' in /blah.php on line 446

Just something to file away in case you're pulling your hair out trying to find an error that "isn't there."
ohcc at 163 dot com
5 years ago
You can use variables within a pair of backticks (``).

= 'www.wuxiancheng.cn';
    echo `
ping -n 3 {$host}`;
To Top