Can't execute PHP script using PHP exec

后端 未结 6 1402
臣服心动
臣服心动 2020-11-30 03:42

I am trying to invoke a script which takes several seconds (web services with 3rd party) using the PHP exec call. After much struggling, I reduced this to the classic hello

相关标签:
6条回答
  • 2020-11-30 03:55

    This runs as if you run the script from browser.

    This came across while working on a project on linux platform.

    exec('wget http://<url to the php script>)
    

    Hope this helps!!

    0 讨论(0)
  • 2020-11-30 03:56

    if you are just simply running a php script one possible way to execute the entire code is to use the include() that will run the php file and output any results. You cannot direct the output to a text file but it should appear in the browser window if you're Hello World php script looks like

    <?php echo "Hello World!"; ?>
    

    then it will spit that out in the browser. So your second code would look like

    <?php include("helloWorld.php");  echo " PHP ROCKS";?>
    

    resulting in a page that would look like,

    Hello world! PHP ROCKS

    0 讨论(0)
  • 2020-11-30 04:09

    To avoid the stated problems of PHP in this area, why not put this in inside a shell script? PHP can then execute the shell script which has all the redirections handled internally.

    If you need to dynamically change things, then why not write the shell script and then execute it (and of course, clean up afterwards)?

    0 讨论(0)
  • 2020-11-30 04:12

    I had this issue also and it turns out this is a bug in php (#11430). The fix is to use php-cli when calling another php script within a php script. So you can still use exec but rather than use php use php-cli when calling it in the browser:

    exec("php-cli  somescript.php");
    

    This worked for me.

    0 讨论(0)
  • 2020-11-30 04:13

    What exec is doing is taking the rightmost command and appending it to your destination. If you have the shebang line in your php script, you shouldn't need to include the binary directive of the php interpreter.

    if you just want the script's output, try:

    exec('/home/quote2bi/tmp/helloworld.php > /tmp/execoutput.txt 2>&1 &')
    

    however if you do not want the errors to be in the file, you should redirect the STDERR prior to outputting to the file. Like so:

    exec('/home/quote2bi/tmp/helloworld.php 2> /dev/null > /tmp/execoutput.txt')
    

    the above should only output the "Hello World" to the execoutput.

    Edit:

    Interesting you are getting this behaviour. You stated the command "ls" worked. Try making an alias for this and forward it to a file like so:

    alias pexec='php /home/quote2bi/tmp/helloworld.php'

    then

    exec('pexec > /tmp/execoutput.txt 2>&1 &')
    

    it seems to be a problem with the way exec handles input as opposed to the shell itself.

    -John

    0 讨论(0)
  • 2020-11-30 04:18

    The problem is with PHP itself, it treats everything as $argv in the script. It doesn´t redirect the output to a file ou to /dev/null.

    I faced the same problem some time ago. What I did is to create a runscript.php in /opt/php-bin and then inside this script run what It should be running. Something like this:

    $script = $argv[1]
    $params = implode(' ', array_slice($argv, 2));
    $cmd    = "{$script} {$params} > /dev/null &";
    
    $output = array();
    $return = 0;
    exec("php {$cmd}", $output, $return);
    
    exit((int)$return);
    

    And then you call it using:

    exec('/opt/php-bin/runscript.php /path/to/your/script.php arg1 arg2')
    

    It´s the only way I managed to get this working.

    0 讨论(0)
提交回复
热议问题