Как выполнить PHP-скрипт из другого PHP-скрипта с помощью оболочки?
у меня есть файл php под названием sample.php следующего содержания:
<?php
echo "Hello World!";
?>
и то, что я хочу сделать, это запустить этот PHP скрипт, использующий второй PHP-скрипт.
Я думаю shell_exec могли бы мне помочь, но я не знаю его синтаксиса. 
кстати, я хочу выполнить эти файлы с помощью cpanel. Поэтому я должен выполнить оболочку. 
есть ли способ сделать это?
7 ответов
Если вам нужно записать вывод php-файла в переменную, используйте функции ob_start и ob_get_contents. См. ниже:
<?php
    ob_start();
    include('myfile.php');
    $myStr = ob_get_contents();
    ob_end_clean();
    echo '>>>>' . $myStr . '<<<<';
?>
Итак, если ваш " myfile.php ' содержит следующее:
<?php
    echo 'test';
?>
тогда ваш выход будет:
>>>>test<<<<
вы можете использовать cURL для удаленных запросов. Ниже от php.net:
<?php
// create a new cURL resource
$ch = curl_init();
// set URL and other appropriate options
curl_setopt($ch, CURLOPT_URL, "http://www.example.com/");
curl_setopt($ch, CURLOPT_HEADER, 0);
// grab URL and pass it to the browser
curl_exec($ch);
// close cURL resource, and free up system resources
curl_close($ch);
?>
вот хороший учебник:http://www.sitepoint.com/using-curl-for-remote-requests/
рассмотрите возможность просмотра этого видео YouTube здесь:http://www.youtube.com/watch?v=M2HLGZJi0Hk
вы можете попробовать это:
основной файл PHP
<?php
// change path/to/php according to how your system is setup
// examples: /usr/bin/php or /opt/lampp/bin/php
echo shell_exec("/path/to/php /path/to/php_script/script.php");
echo "<br/>Awesome!!!"
?>
вторичный файл PHP
<?php
echo "Hello World!";
?>
вывод при запуске основного файла PHP
Hello World!
Awesome!!!
надеюсь, это поможет вам.
попробуйте это:
<?php
// change path/to/php according to how your system is setup
// examples: /usr/bin/php or /opt/lampp/bin/php
$output = shell_exec("/path/to/php /path/to/php_script/script.php");
print_r($output);
?>
Это может помочь вам.
важно подчеркнуть, что включение/выполнение пользовательского кода опасно. Использование системного вызова (exec, shell_exec, system) вместо include помогает отделить контекст выполнения, но это не намного безопаснее. Подумайте о надлежащей санитарии или песочнице.
имея это в виду, вот рабочий пример, включая создание (временного) файла, его выполнение и очистку:
<?php
   // test content  
   $code = <<<PHP
   echo "test";
PHP;
   // create temporary file
   $d=rand();
   $myfile="$d.php";
   file_put_contents($myfile,"<?php\n$code\n?>");
   // start capture output
   ob_start();
   // include generate file
   // NOTE: user-provided code is unsafe, they could e.g. replace this file.
   include($myfile);
   // get capture output
   $result = ob_get_clean();
   // remove temporary file
   unlink($myfile);
   // output result
   echo "================\n" . $result . "\n================\n" ;
выход:
================
test
================
terminal view:
abgth@ubuntu:/var/www$ cat > test.php
  <?php
      echo shell_exec("php5 /var/www/check.php");     
  ?>
abgth@ubuntu:/var/www$ cat > check.php
  <?php
      echo 'hi';
  ?>
abgth@ubuntu:/var/www$ php5 test.php
hi
Я надеюсь, что вы ищете этот
перейдите в терминал и введите
имя файла php.в PHP
именем.php должен быть именем файла, который вы хотите выполнить!